Por que os arquivos tar.xz criados com Python tar são 15 vezes menores do que macOS tar

Aproximadamente. trad. : Esta não é uma tradução comum, pois não é baseada em um artigo separado, mas em um caso recente com Stack Exchange, que se tornou o principal hit do recurso neste mês. Seu autor faz uma pergunta, cuja resposta acabou sendo uma verdadeira revelação para alguns visitantes do site.





Compactando diretórios em ~ 1,3 GB, cada um com 1440 arquivos JSON, encontrei uma diferença de 15x entre o tamanho dos arquivos compactados usando tar



macOS ou Raspbian 10 (Buster) e arquivos obtidos usando a biblioteca tarfile integrada no Python.





Exemplo de trabalho mínimo

Este script compara os dois métodos:





#!/usr/bin/env python3

from pathlib import Path 
from subprocess import call 
import tarfile

fullpath = Path("/Users/user/Desktop/temp/tar/2021-03-11") 
zsh_out = Path(fullpath.parent, "zsh-archive.tar.xz") 
py_out = Path(fullpath.parent, "py-archive.tar.xz")

# tar using terminal 
# tar cJf zsh-archive.tar.xz folderpath
call(["tar", "cJf", zsh_out, fullpath])

# tar using tarfile library 
with tarfile.open(py_out, "w:xz") as tar:
    tar.add(fullpath, arcname=fullpath.stem)

# Print filesizes 
print(f"zsh tar filesize: {round(Path(zsh_out).stat().st_size/(1024*1024), 2)} MB") 
print(f"py tar filesize: {round(Path(py_out).stat().st_size/(1024*1024), 2)} MB")
      
      



O resultado é este:





zsh tar filesize: 23.7 MB
py tar filesize: 1.49 MB
      
      



As seguintes versões foram usadas:





  • tar



    no MacOS: bsdtar 3.3.2 - libarchive 3.3.2 zlib/1.2.11 liblzma/5.0.5 bz2lib/1.0.6



    ;





  • tar



    Raspbian a 10: xz (XZ Utils) 5.2.4 liblzma 5.2.4



    ;





  • tarfile



    Python: 0.9.0



    .





:





diff -r py-archive-expanded zsh-archive-expanded
      
      



.





« » ( ) :





➜ diff zsh-archive.tar.xz py-archive.tar.xz
Binary files zsh-archive.tar.xz and py-archive.tar.xz differ
      
      



Quicklook ( Betterzip) , -:





À esquerda está zsh-archive.tar.xz, à direita está py-archive.tar.xz.
— zsh-archive.tar.xz, — py-archive.tar.xz.

zsh



, Python — . , .





? ? , Python- ? 15- - Python-?





: , tarlib



Python ; BSD- tar



.





:

, , BSD- GNU- tar



.





GNU tar



--sort



:





ORDER



, none



, name



inode



.





--sort=none



— , .





GNU tar

GNU tar



Mac:





brew install gnu-tar
      
      



'tar' , --sort



:





gtar --sort='name' -cJf zsh-archive-sorted.tar.xz /Users/user/Desktop/temp/tar/2021-03-11
      
      



zsh-archive-sorted.tar.xz



1,5 — , , Python-.





, , JSON-, ( — unixtime), BSD tar



:





cat *.json > all.txt
tar cJf zsh-cat-archive.tar.xz all.txt
      
      



zsh-cat-archive.tar.xz



1,5 .





Python- tarfile

, TarFile.add Python , tarfile



Python :





. , recursive False. .





, , , :





JSON- . , .





, . , .





P.S.

UPD: — XZ/LZMA — , @iliazeus!





:





  • «Git happens! 6 Git »;





  • « »;





  • « ».








All Articles