AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 570477
Accepted
Pol
Pol
Asked: 2020-03-01 17:18:16 +0800 CST2020-03-01 17:18:16 +0800 CST 2020-03-01 17:18:16 +0800 CST

GZip não produz o mesmo resultado compactado no macOS vs Linux

  • 772

Eu tenho alguns milhares de arquivos que são compactados individualmente com GZip (passando, é claro, o -nsinalizador para que a saída seja determinística). Eles então vão para um repositório Git. Acabei de descobrir que para 3 desses arquivos, o Gzip não produz a mesma saída no macOS vs Linux. Aqui está um exemplo:

Mac OS

$ cat Engine/Extras/ThirdPartyNotUE/NoRedist/EnsureIT/9.7.0/bin/finalizer | shasum -a 256
0ac378465b576991e1c7323008efcade253ce1ab08145899139f11733187e455  -

$ cat Engine/Extras/ThirdPartyNotUE/NoRedist/EnsureIT/9.7.0/bin/finalizer | gzip --fast -n | shasum -a 256
6e145c6239e64b7e28f61cbab49caacbe0dae846ce33d539bf5c7f2761053712  -

$ cat Engine/Extras/ThirdPartyNotUE/NoRedist/EnsureIT/9.7.0/bin/finalizer | gzip -n | shasum -a 256
3562fd9f1d18d52e500619b4a5d5dfa709f5da8601b9dd64088fb5da8de7b281  -

$ gzip --version
Apple gzip 272.250.1

Linux

$ cat Engine/Extras/ThirdPartyNotUE/NoRedist/EnsureIT/9.7.0/bin/finalizer | shasum -a 256
0ac378465b576991e1c7323008efcade253ce1ab08145899139f11733187e455  -

$ cat Engine/Extras/ThirdPartyNotUE/NoRedist/EnsureIT/9.7.0/bin/finalizer | gzip --fast -n | shasum -a 256
10ac8b80af8d734ad3688aa6c7d9b582ab62cf7eda6bc1a0f08d6159cad96ddc  -

$ cat Engine/Extras/ThirdPartyNotUE/NoRedist/EnsureIT/9.7.0/bin/finalizer | gzip -n | shasum -a 256
cbf249e3a35f62a4f3b13e2c91fe0161af5d96a58727d17cf7a62e0ac3806393  -

$ gzip --version
gzip 1.6
Copyright (C) 2007, 2010, 2011 Free Software Foundation, Inc.
Copyright (C) 1993 Jean-loup Gailly.
This is free software.  You may redistribute copies of it under the terms of
the GNU General Public License <http://www.gnu.org/licenses/gpl.html>.
There is NO WARRANTY, to the extent permitted by law.

Written by Jean-loup Gailly.

Como isso é possível? Achei que a implementação do GZip era completamente padrão?

ATUALIZAÇÃO: Apenas para confirmar que as versões macOS e Linux produzem a mesma saída na maioria das vezes, ambos os sistemas operacionais produzem o mesmo hash para:

$ echo "Vive la France" | gzip --fast -n | shasum -a 256
af842c0cb2dbf94ae19f31c55e05fa0e403b249c8faead413ac2fa5e9b854768  -
linux gzip
  • 4 4 respostas
  • 6125 Views

4 respostas

  • Voted
  1. Best Answer
    schnaader
    2020-03-02T08:18:51+08:002020-03-02T08:18:51+08:00

    Observe que o algoritmo de compactação (Deflate) no GZip não é estritamente bijetivo. Para elaborar: Para alguns dados, há mais de uma saída compactada possível dependendo da implementação algorítmica e dos parâmetros usados. Portanto, não há garantia de que o Apple GZip e o gzip 1.6 retornarão a mesma saída compactada . Essas saídas são todos fluxos GZip válidos, o padrão apenas garante que todas essas saídas possíveis serão descompactadas para os mesmos dados originais.

    • 60
  2. vonbrand
    2020-03-01T17:53:45+08:002020-03-01T17:53:45+08:00

    O formato deve ser bem estável, mas veja sua descrição . Ele contém um campo para ID do sistema operacional. Obviamente, isso será diferente para MacOS e Linux e FreeBSD e ...

    • 19
  3. fraxinus
    2020-03-02T11:04:37+08:002020-03-02T11:04:37+08:00

    O formato Gzip é padrão, a implementação - não necessariamente. A Wikipedia lista pelo menos 5 implementações independentes de free/oss e também existem outras proprietárias. A Apple claramente gera uma string de versão diferente.

    O formato e o algoritmo permitem muita liberdade e muitas opções de design que são uma questão de gosto e/ou funcionam melhor em diferentes casos de uso.

    Veja Arquivos Zip: Histórico, Explicação e Implementação

    Eu geralmente esperaria que os resultados fossem os mesmos entre diferentes implementações apenas para uma pequena porcentagem de arquivos pequenos.

    • 10
  4. Alfred P.
    2020-03-02T16:29:07+08:002020-03-02T16:29:07+08:00

    Tem certeza de que os arquivos antes da compactação são idênticos? Alguns arquivos de texto chekout VCS de forma diferente, usando UTF8 ou não, janelas ou linux newlines, ...

    Execute o comando SHA nos arquivos originais para ver se você está fazendo a mesma coisa.

    Talvez tente o nível de compactação 0 para ver se isso funciona corretamente.

    Encontre alguns arquivos simples que você pode postar aqui que são codificados de forma diferente em ambos os sistemas.

    Os arquivos são descompactados corretamente em ambos os sistemas? Execute o comando SHA novamente.

    E sempre se pergunte: isso importa? :)

    • 0

relate perguntas

  • Existe uma maneira de fazer ls mostrar arquivos ocultos apenas para determinados diretórios?

  • Inicie/pare o serviço systemd usando o atalho de teclado [fechado]

  • Necessidade de algumas chamadas de sistema

  • astyle não altera a formatação do arquivo de origem

  • Passe o sistema de arquivos raiz por rótulo para o kernel do Linux

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve