Como faço para verificar a origem e o arquivo de um pacote?

5

Estou tentando descobrir por que um pacote não foi atualizado autônomo e voltei meus olhos para a configuração Allowed-Origins . No entanto, não sei como verificar a origem e o arquivamento de pacotes no cache do apt. Como faço isso?

    
por Daniel C. Sobral 27.10.2010 / 16:32

3 respostas

7

O método para encontrar a identificação do pacote (Origem, Arquivo, etc) é verificar o arquivo Release do repositório. O arquivo Release está localizado no diretório /var/lib/apt/lists/ e é nomeado após o caminho do URI do seu repositório.

Por exemplo, o arquivo Release do meu sistema operacional Debian é /var/lib/apt/lists/mirrors.ustc.edu.cn_dotdeb_packages.dotdeb.org_dists_wheezy_Release . Seu conteúdo é como abaixo:

Origin: packages.dotdeb.org
Label: packages.dotdeb.org
Suite: stable
Codename: wheezy
Architectures: i386 amd64
Components: all
MD5Sum:
 7b0372c2d39e7574ff3360513577371a 90169 all/binary-amd64/Packages
 d9d802d8f7c7db495ee3d66202e757df 16777 all/binary-amd64/Packages.bz2
 c878a40df3d1c1a35a2df2bb5f1b0945 17803 all/binary-amd64/Packages.gz
 bab1973f5a315e894ba11c93476d2eea 90134 all/binary-i386/Packages
 3ad627d656bd2b663f63184a3d2dead6 16802 all/binary-i386/Packages.bz2
 9a39629120f5735e727d9c5f7b93685e 17806 all/binary-i386/Packages.gz
 f0d3d108cc53373e65bf008a454a6c9b 13431 all/source/Sources
 f52943cb088a96e24aff985ffbbb5dd2 4239 all/source/Sources.bz2
 a7cc0f55dc5d885dda5ea6fa14a20492 4291 all/source/Sources.gz
SHA1:
 0b396db57ee74d25a66c3b003dfc8df40575ec22 90169 all/binary-amd64/Packages
 9730122304e2a5018231fd9735a7cddb215b9264 16777 all/binary-amd64/Packages.bz2
 fc31511be43f3bd62509843039ae7ee5fa2e6e42 17803 all/binary-amd64/Packages.gz
 f33c1260a3db7593ef9dd7d8c8717d754d34652a 90134 all/binary-i386/Packages
 e1032286e95fb396ddef773799675e2539b8dd76 16802 all/binary-i386/Packages.bz2
 bc566974412402f959f9f519450b35151bc12c59 17806 all/binary-i386/Packages.gz
 e8b9a8c659bae2ac41187bb9bbc3e866527aaf57 13431 all/source/Sources
 2d1f8e9656c23f899d0475a5ef097b13d1724a60 4239 all/source/Sources.bz2
 0bd911daf399f742279794f6722d937420616676 4291 all/source/Sources.gz
SHA256:
 fb102dbedf57e311e9fd4694edeb856bd186e4f5301765efd8ca9210a607a3dd 90169 all/binary-amd64/Packages
 66d6eaea52e1c69fcc9ef2279bf808d8f55cdfa932e72e4fada11d2bddcda9a7 16777 all/binary-amd64/Packages.bz2
 16d5513b83fb5c442e12fb0c54bbe7fb1c065c28810b158b8f97444063af2d38 17803 all/binary-amd64/Packages.gz
 1dacf00be5f242bd89f142e1a8e6b660525398b04558ac3715b6f05746207d4c 90134 all/binary-i386/Packages
 2e3ee584d47ad2ec18b6a2b06e08facb62ed09c7c51dfde7bdc500901c475088 16802 all/binary-i386/Packages.bz2
 fea4c9c9fa10f07c2821e9e0dac464d3b6443770727a907766f98716e52425db 17806 all/binary-i386/Packages.gz
 2b124de5b3bcabe694d637621f448106787df104bcb69fbdf4c6057103347cbd 13431 all/source/Sources
 6a9ccffeb3392f8fcc158fcf8da1c2dcb2435afcc9e9d1ca7cb5d2e070e5f630 4239 all/source/Sources.bz2
 761c5d086a7b418c75e680a3d9320cb8958cb00e688a4379bb73ce967b632391 4291 all/source/Sources.gz

Em seguida, adiciono a seguinte linha na seção Unattended-Upgrade::Origins-Pattern :

        "o=packages.dotdeb.org,a=stable";
    
por 24.08.2013 / 16:14
4

O comando a seguir lista todas as versões de um determinado pacote disponíveis de todas as fontes configuradas em seu sources.list :

apt-cache policy <packagename>

EDITAR

Aqui está um exemplo de saída de um sistema com várias fontes em sources.list .

# apt-cache policy nano
nano:
  Installed: 2.0.7-5
  Candidate: 2.2.5-1
  Version table:
     2.2.5-1 0
        500 http://mirrors.kernel.org sid/main Packages
     2.2.4-1 0
        500 http://mirrors.kernel.org squeeze/main Packages
 *** 2.0.7-5 0
        500 http://mirrors.kernel.org lenny/main Packages
        100 /var/lib/dpkg/status

A tabela de versões mostra as versões, prioridades, URLs de arquivamento e conjuntos de pacotes disponíveis.

    
por 27.10.2010 / 17:10
2

Ok, eu encontrei uma maneira que é suficiente para o meu propósito imediato, mesmo que não seja geral o suficiente. Vou deixar a resposta aqui, mas não vou aceitar.

Ao executar unattended-upgrade -d , ele registrará informações sobre os pacotes com upgrades disponíveis. Esta informação contém origem e arquivo. Por exemplo:

2010-10-27 13:21:28,734 DEBUG Checking: postgresql-8.4 (["component: 'main' archive: 'lenny-backports' origin: 'Debian Backports' label: 'Debian Backports' site 'backports.debian.org' isTrusted: 'True'"])

O script unattended-upgrade em si é Python e usa python-apt , uma interface para libapt-pkg , para obter essa informação.

    
por 27.10.2010 / 17:33