Chun-Hung Hsiao created MESOS-7617:
--------------------------------------

             Summary: UCR cannot read docker images containing long file paths
                 Key: MESOS-7617
                 URL: https://issues.apache.org/jira/browse/MESOS-7617
             Project: Mesos
          Issue Type: Bug
          Components: containerization
            Reporter: Chun-Hung Hsiao


The latest Docker uses go 1.7.5 
(https://github.com/moby/moby/blob/master/CHANGELOG.md#contrib-1), in which the 
{{archive/tar}} package has a bug that cannot handle file paths longer than 100 
characters (https://github.com/golang/go/issues/17630). As a result, Docker 
will generate images containing ill-formed tar files (details below) when there 
are long paths. Docker itself understands the ill-formed image fine, but a 
standard tar program will interpret the image as if all files with long paths 
are placed under the root directory (https://github.com/moby/moby/issues/29360).

This bug has been fixed in go 1.8, but since Docker is still using the bugged 
version, we might need to handle these ill-formed images created by Dcoker 
utilities.

NOTE: It is confirmed that the {{archive/tar}} package in go 1.8 cannot 
correctly extract the ill-formed tar files, but the one in go 1.7.5 could.

Details: the {{archive/tar}} package uses {{USTAR}} format to handle files with 
100+-character-long paths (by only putting file name in the {{name}} field and 
the path in the {{prefix}} field in the tar header), but uses {{OLDGNU}}'s 
magic string, which does not understand the {{prefix}} field, so a standard tar 
program will extract such files under the current directory.



--
This message was sent by Atlassian JIRA
(v6.3.15#6346)

Reply via email to