Zaskoczyłem króliczą dziurę po tym, jak inne odpowiedzi zawiodły mnie, i udało mi się dowiedzieć, że moja wersja tar (1.27.1 z repozytorium OSS openSUSE 42.3) pax
domyślnie używa niedeterministycznego formatu archiwalnego, co oznacza, że nawet bez kompresji (a nawet jawnego ustawienia mtime) archiwa utworzone przy pomocy tar z tych samych plików mogą się różnić:
$ echo hi > test.file
$ tar --create --to-stdout test.file # long form of `tar cO test.file`
./PaxHeaders.13067/test.file0000644000000000000000000000013213427447703012603 xustar0030 mtime=1549684675.835011178
30 atime=1549684726.410510251
30 ctime=1549684675.835011178
test.file0000644000175000001440000000000313427447703013057 0ustar00hartusers00000000000000hi
$ tar --create --to-stdout test.file
./PaxHeaders.13096/test.file0000644000000000000000000000013213427447703012605 xustar0030 mtime=1549684675.835011178
30 atime=1549684726.410510251
30 ctime=1549684675.835011178
test.file0000644000175000001440000000000313427447703013057 0ustar00hartusers00000000000000hi
Zauważ, że powyższe dane wyjściowe różnią się, mimo że nie jest używana żadna kompresja ; nieskompresowane treści archiwów (generowane przez dwukrotne uruchomienie tar na tej samej zawartości) są różne, więc skompresowana zawartość będzie się różnić, nawet gdy będzie używana, GZIP=-n
jak sugerują inne odpowiedzi
Aby obejść ten problem, możesz określić --format gnu
:
$ tar --create --format gnu --to-stdout test.file
test.file0000644000175000001440000000000313427447703011557 0ustar hartusershi
$ tar --create --format gnu --to-stdout test.file
test.file0000644000175000001440000000000313427447703011557 0ustar hartusershi
Działa to z powyższą sugestią dotyczącą gzip:
# gzip refuses to write to stdout, so we'll use the `-f` option to create a file
$ GZIP=-n tar --format gnu -czf test.file.tgz test.file && md5sum test.file.tgz
0d8c7b3bdbe8066b516e3d3af60ade75 test.file.tgz
$ GZIP=-n tar --format gnu -czf test.file.tgz test.file && md5sum test.file.tgz
0d8c7b3bdbe8066b516e3d3af60ade75 test.file.tgz
# without GZIP=-n we see a different hash
$ tar --format gnu -czf test.file.tgz test.file && md5sum test.file.tgz
682ce0c8267b90f4103b4c29903c5a8d test.file.tgz
Jednak oprócz uzasadnionych powodów preferowania lepszych formatów kompresji niż gzip , możesz rozważyć użycie zamiast tego xz (który tar obsługuje również z flagami --xz
lub -J
zamiast -z
), ponieważ oszczędza ci to kroku; domyślnym zachowaniem xz
jest generowanie tego samego skompresowanego wyjścia, gdy nieskompresowana zawartość jest taka sama, więc nie ma potrzeby określania opcji takiej jak GZIP=-n
:
$ tar --format gnu --xz -cf test.file.txz test.file && md5sum test.file.txz
dea99037d4b0ee4565b3639e93ac0930 test.file.txz
$ tar --format gnu --xz -cf test.file.txz test.file && md5sum test.file.txz
dea99037d4b0ee4565b3639e93ac0930 test.file.txz
touch filename
która zmiana zmodyfikowanego czasu pliku wystarczy, aby zmienić sumę kontrolną.