Difference between revisions of "Pacman (Português)"

From ArchWiki
Jump to: navigation, search
m (improve related links and templates)
Line 1: Line 1:
[[Category:Package management (Português)]]
+
{{Lowercase title}}
 +
[[Package management (Português)]]
 +
[[ar:Pacman]]
 
[[cs:Pacman]]
 
[[cs:Pacman]]
 
[[da:Pacman]]
 
[[da:Pacman]]
 
[[de:Pacman]]
 
[[de:Pacman]]
 
[[el:Pacman]]
 
[[el:Pacman]]
[[en:Pacman]]
 
 
[[es:Pacman]]
 
[[es:Pacman]]
 +
[[en:Pacman]]
 
[[fr:Pacman]]
 
[[fr:Pacman]]
 
[[id:Pacman]]
 
[[id:Pacman]]
Line 14: Line 16:
 
[[nl:Pacman]]
 
[[nl:Pacman]]
 
[[pl:Pacman]]
 
[[pl:Pacman]]
 +
[[pt:Pacman]]
 
[[ro:Pacman]]
 
[[ro:Pacman]]
 
[[ru:Pacman]]
 
[[ru:Pacman]]
Line 22: Line 25:
 
[[zh-CN:Pacman]]
 
[[zh-CN:Pacman]]
 
[[zh-TW:Pacman]]
 
[[zh-TW:Pacman]]
==Descrição==
+
{{Article summary start| Sumário}}
O gestor de pacotes '''Pacman''' é uma das grandes vantagens do Arch Linux. Combina um simples pacote no formato binário com um facil sistema de compilação fácil de usar (ver [[makepkg]] e [[ABS]]). Com o '''Pacman''' é fácil gerir pacotes, sendo os oficiais dos repositórios do Arch ou os que são feitos pelo utilizador.
+
{{Article summary text|Pacman é o [[Wikipedia:Package management system|gerenciador de pacotes]] do Arch Linux. Gerenciadores de pacotes são usados para instalar, atualizar e remover programas. Este artigo aborda o uso básico com dicas e solução de problemas.}}
O '''Pacman''' pode manter um sistema actualizado através da sincronização de listas de pacotes com o servidor "mestre". Este modelo de servidor/cliente permite o utilizador fazer o download/instalar pacotes com um simples comando, sendo resolvidas todas as dependências. (semelhante ao apt-get do Debian).
+
{{Article summary heading|Visão Geral}}
 +
{{Article summary text|Os Pacotes no Arch Linux são construídos usando o [[makepkg]] e um script de construção personalizado para cada pacote (conhecido como [[PKGBUILD]]). Uma vez empacotado, o programa pode ser instalado e gerenciado com o [[pacman]]. PKGBUILDs para software nos [[repositórios oficiais]] são disponíves na árvore do [[ABS]]; mais de milhares estão disponíveis no (não suportado) [[Arch User Repository]].}}
 +
{{Article summary heading|Relacionado}}
 +
{{Article summary wiki|Downgrading Packages}}
 +
{{Article summary wiki|Improve Pacman Performance}}
 +
{{Article summary wiki|Pacman GUI Frontends}}
 +
{{Article summary wiki|Pacman Rosetta}}
 +
{{Article summary wiki|Pacman Tips}}
 +
{{Article summary wiki|Pacman package signing}}
 +
{{Article summary wiki|FAQ#Package Management}}
 +
{{Article summary wiki|pacman-key}}
 +
{{Article summary wiki|Pacnew and Pacsave Files}}
 +
{{Article summary heading|Recursos}}
 +
{{Article summary link|libalpm(3) Manual Page|https://www.archlinux.org/pacman/libalpm.3.html}}
 +
{{Article summary link|pacman(8) Manual Page|https://www.archlinux.org/pacman/pacman.8.html}}
 +
{{Article summary link|pacman.conf(5) Manual Page|https://www.archlinux.org/pacman/pacman.conf.5.html}}
 +
{{Article summary link|repo-add(8) Manual Page|https://www.archlinux.org/pacman/repo-add.8.html}}
 +
{{Article summary end}}
  
==Utilização==
+
O [[Wikipedia:Package management system|gerenciador de pacote]] '''[https://www.archlinux.org/pacman/ pacman]''' é uma das grandes vantagens do Arch Linux. Combina um simples pacote no formato binário, com um fácil uso de [[Arch Build System|sistema de compilação]]. A meta do pacman é tornar o mais fácil possivel gerenciar pacotes, sejam eles dos [[Official Repositories|oficiais repositórios Arch]] ou das próprias compilações do usuário.
  
Para realmente aprender o que o '''Pacman''' consegue fazer, leia <code>man pacman</code>. O que se segue é apenas uma pequena demonstração das operações que podem ser feitas.
+
Pacman mantém o sistema atualizado, listas de pacotes de sincronização com o servidor mestre. Este modelo servidor/cliente também permite o usuário baixar/instalar pacotes com um simples comando, completo com todas as dependências requeridas.
  
===Instalar e Remover Pacotes===
+
Pacman é escrito na linguagem de programação C e usa o formato de pacote {{ic|.pkg.tar.xz}}.
Antes de instalar pacotes, é boa ideia sincronizar a lista local de pacotes com a dos repositórios e actualizar o seu sistema com:
+
  
pacman -Syu
+
{{Dica |O oficial pacote {{Pkg|pacman}} também contém outras ferramentas úteis, tais como o '''makepkg''', '''pactree''', '''vercmp''' e mais: executa {{ic|pacman -Ql pacman <nowiki>|</nowiki> grep bin}} para ver uma lista completa.}}
  
Para instalar ou actualizar apenas um pacote ou uma lista de pacotes (incluindo dependencias) siga o seguinte comando:
+
== Configuração ==
  
pacman -S nome_pacote1 nome_pacote2
+
Os ajustes do Pacman estão localizados em {{ic|/etc/pacman.conf}}. Este é o local onde o usuário configura o programa para funcionar da forma desejada. Informações detalhadas sobre o arquivo de configuração pode ser encontrada em [https://www.archlinux.org/pacman/pacman.conf.5.html man pacman.conf].
  
Por vezes há mais versões de um pacote em diferentes repositórios (ex:  extra e testing). Pode especificar qual deles instalar:
+
=== Opções gerais ===
  
pacman -S extra/nome_pacote
+
Opções gerais estão na seção {{ic|[options]}}. Leia a página de manual ou olhe no padrão {{ic|pacman.conf}} para obter informações sobre o que pode ser feito aqui.
pacman -S testing/nome_pacote
+
  
Para remover um pacote, deixando todas as dependências instaladas:
+
==== Pular pacotes para não serem atualizados ====
  
pacman -R nome_pacote
+
Para pular a atualização de um pacote específico, faça:
  
Para remover todas as dependências de um pacote que não estão a ser utilizadas por nenhum outro:
+
IgnorePkg=linux
  
pacman -Rs nome_pacote
+
Para vários pacotes use uma lista separada por espaço, ou use adicionais linhas {{ic|IgnorePkg}}.
  
Para remover um pacote sem verificar as suas dependências (perigoso):
+
==== Pular um grupos de pacotes para não serem atualizados ====
  
pacman -Rd nome_pacote
+
Tal como acontece com os pacotes, pular um grupo de pacote inteiro também é possível:
  
===Actualizar o Sistema===
+
IgnoreGroup=gnome
  
O '''Pacman''' pode actualizar todos os pacotes do sistema com apenas um comando. Este processo poderá demorar algum tempo, variando de acordo com as caracteristicas do seu computador, ligação de internet e a quantidade de pacotes a actualizar.
+
==== Pular arquivos para não serem instalados no sistema ====
Primeiro vai sincronizar os repositorios (y) e seguidamente actualiza os pacotes necessários (u)
+
  
pacman -Syu
+
Para pular sempre a instalação de lista de diretórios sob {{Ic|NoExtract}}. Por exemplo, para evitar a instalação de units [[systemd]] use:
  
===Fazer Query à Base de Dados de Pacotes===
+
NoExtract=usr/lib/systemd/system/*
  
O '''Pacman''' consegue procurar na base de dados de pacotes uma lista destes. Pode apenas escrever parte do nome de um pacote para procurar todos os pacotes correspondentes a uma lista de caracteres (string):
+
=== Repositórios ===
  
pacman -Ss pacote
+
A seção define quais [[Official Repositories|repositórios]] usar, como referido no {{ic|/etc/pacman.conf}}. Podem ser mencionados aqui diretamente ou incluídos de outro arquivo (como {{ic|/etc/pacman.d/mirrorlist}}), tornando-se assim necessário manter apenas uma lista. Veja [[Mirrors|aqui]] para configuração de espelho.
  
Para procurar os pacotes instalados:
+
{{hc|/etc/pacman.conf|2=
 +
#[testing]
 +
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
pacman -Qs pacote
+
[core]
 +
SigLevel = PackageRequired
 +
Include = /etc/pacman.d/mirrorlist
  
Uma vez que conheça o nome dos pacotes que está à procura, pode visualizar algumas informações no pacote. Nota: ''query info'' (-Qi) vai mostrar mais informação do que ''sync info'' (-Si), desde que o pacote esteja instalado.
+
[extra]
 +
SigLevel = PackageRequired
 +
Include = /etc/pacman.d/mirrorlist
  
pacman -Si pacote
+
#[community-testing]
pacman -Qi pacote
+
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
Para uma lista dos ficheiros que estão num pacote:
+
[community]
 +
SigLevel = PackageRequired
 +
Include = /etc/pacman.d/mirrorlist
  
pacman -Ql pacote
+
# If you want to run 32 bit applications on your x86_64 system,
 +
# enable the multilib repositories as required here.
  
Para uma lista dos pacotes instalados como dependencias mas que já não sao necessários:
+
#[multilib-testing]
 +
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
pacman -Qdt
+
#[multilib]
 +
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
Pode também fazer um ''query'' sobre a qual pacote pertence um ficheiro presente no sistema.
+
# An example of a custom package repository. See the pacman manpage for
 +
# tips on creating your own repositories.
 +
#[custom]
 +
#SigLevel = Optional TrustAll
 +
#Server = file:///home/custompkgs}}
  
pacman -Qo /caminho/do/ficheiro
+
Cuidados devem ser tomados ao usar o repositório [testing]. Ele está em desenvolvimento ativo e a atualização pode fazer que alguns pacotes parem de funcionar. As pessoas que usam o repositório [testing] são encorajadas a se increver em [https://mailman.archlinux.org/mailman/listinfo/arch-dev-public arch-dev-public mailing list] para obter informações atualizadas.}}
  
===Outros usos===
+
=== Segurança de pacotes ===
O '''Pacman''' é uma ferramenta de gestão de pacotes um pouco extensiva. Aqui estão algumas outras funcionalidades.
+
* Fazer o download de um pacote sem o instalar:
+
pacman -Sw nome_pacote
+
  
* Instalar um pacote local (sem ser de um repositório):
+
Pacman suporta 4 assinaturas de pacotes, que adiciona um nível extra de segurança para os pacotes. A configuração padrão, {{ic|1=SigLevel = Required DatabaseOptional}}, habilita a verificação de assinaturas para todos os pacotes em um nível global: este pode ser substituido por linhas por repositório {{ic|SigLevel}}, como mostrado acima. Para mais detalhes sobre pacote de assinatura e verificação de assinatura, dê uma olhada em [[pacman-key]].
  pacman -U /caminho/do/pacote/nome_pacote-versão.pkg.tar.gz
+
  
* Apagar a ''cache'' de pacotes (/var/cache/pacman/pkg):
+
== Uso ==
pacman -Scc
+
  
Para mais informação detalhada fazer <code>pacman --help</code> ou <code>man pacman</code>
+
O que se segue é apenas uma pequena amostra das operações que o pacman pode executar. Para ler mais exemplos, consulte [https://www.archlinux.org/pacman/pacman.8.html man pacman]. Para uma introdução, veja [[pacman - An Introduction]].
  
==Configuração==
+
=== Instalando Pacotes ===
A configuração do '''Pacman''' está presente em <code>/etc/pacman.conf</code>. Para saber como fazer a sua própria configuração ver <code>man pacman.conf</code>
+
  
===Opções Gerais===
+
==== Instalando Pacotes especificos ====
As opções gerais estão na secção [options]. Leia a página de manual ou olhe para a configuração por defeito do ''pacman.conf'' para informação sobre o que pode ser feito.
+
  
===Repositórios===
+
Para instalar um único pacote ou lista de pacotes (incluindo dependências), execute o seguinte comando:
Nesta secção pode definir quais os repositórios a utilizar, como referido em {{ic|/etc/pacman.conf}} que está localizado em {{ic|/etc/pacman.d/}}. Os repositórios podem ser definidos directamente neste ficheiro ou incluídos noutro ficheiro. Estes ficheiros podem ser encontradas no directório {{ic|/etc/pacman.d/}}, sendo eles '''community''', '''core''', '''extra''' e '''testing'''. É importante editar cada um deles para incluir os repositórios que desejar. O que se segue é um exemplo para os repositórios oficiais que têm muitos [[mirrors]]. Evite utilizar ''ftp.archlinux.org'' [https://www.archlinux.org/news/302/]
+
  
<pre>
+
# pacman -S ''package_name1'' ''package_name2'' ...
[nome-repositório]
+
Server = ftp://servidor.net/repo
+
</pre>
+
  
<pre>
+
Às vezes, há várias versões de um pacote nos diferentes repositórios, por exemplo [extra] e [testing]. Para instalar a versão anterior, o repositṕorio deve ser definido na frente:
[core]
+
 
# Adicionar aqui os seus servidores preferidos, serão utilizados primeiro
+
# pacman -S extra/''package_name''
Include = /etc/pacman.d/core
+
 
</pre>
+
==== Instalando grupos de pacotes ====
 +
 
 +
Alguns pacotes pertencem a um grupo de pacotes que podem ser instalados simultaneamente. Por exemplo, o comando:
 +
 
 +
# pacman -S gnome
 +
 
 +
este comando solicitará que você selecione os pacotes do grupo {{Grp|gnome}} que você deseja instalar.
 +
 
 +
Às vezes, um grupo de pacote conterá uma grande quantidade de pacotes, e pode haver só alguns que você quer ou não instalar. Em vez de digitar todos os números, exceto aqueles que você não quer, pode ser mais conveniente selecionar ou excluir pacotes ou intervalos de pacotes com a seguinte sintaxe:
 +
 
 +
Digite uma seleção (padrão=todos): 1-10 15
 +
 
 +
irá selecionar pacotes 1 até 10 e 15 para a instalação, ou:
 +
 
 +
Digite uma seleção (padrão=todos):: ^5-8 ^2
 +
 
 +
irá selecionar todos os pacotes, exceto 5 até 8 e 2 para a instalação.
 +
 
 +
Para ver quais pacotes pertencem ao grupo gnome, execute:
 +
 
 +
# pacman -Sg gnome
 +
 
 +
Também visite https://www.archlinux.org/groups/ para saber quais os grupos de pacotes disponíveis.
 +
 
 +
{{Nota |Se um pacote na lista já está instalado no sistema, ele será reinstalado mesmo se já estiver atualizado. Este comportamento pode ser substituído com a opção {{ic|--needed}}.}}
 +
 
 +
{{Dica |1=Ao instalar os pacotes, ''não'' atualiza a lista de pacotes sem [[#Upgrading packages|atualização]] do sistema (ex. {{ic|pacman -Sy ''package_name''}}), isso pode ocasinar erros de dependêcias. Veja [[#Partial upgrades are unsupported]] e https://bbs.archlinux.org/viewtopic.php?id=89328.}}
 +
 
 +
=== Removendo pacotes ===
 +
 
 +
Para remover um único pacote, deixando todas as suas dependências instaladas:
 +
 
 +
# pacman -R ''package_name''
 +
 
 +
Para remover um pacote e suas dependências que não são exigidas por qualquer outro pacote instalado:
 +
 
 +
# pacman -Rs ''package_name''
 +
 
 +
Para remover um pacote, suas dependências e todos os pacotes que dependem deste pacote:
 +
 
 +
{{Dica |Esta operação é recursiva, e deve ser usada com cuidado, pois pode remover muitos pacotes potencialmente necessários.}}
 +
 
 +
# pacman -Rsc ''package_name''
 +
 
 +
Para remover um pacote, o qual é exigido por outro pacote, sem remover o pacote dependente:
 +
 
 +
# pacman -Rdd ''package_name''
 +
 
 +
O pacman salva arquivos de configuração importantes ao remover certos aplicativos e os nomes com a extensão: {{ic|.pacsave}}. Para prevenir a criação desses arquivos de backup use a opção {{ic|-n}}:
 +
 
 +
# pacman -Rn ''package_name''
 +
 
 +
{{Nota|Pacman não removerá as configurações que o próprio aplicativo cria (por exemplo, "dotfiles" na pasta home).}}
 +
 
 +
=== Atualizando pacotes ===
 +
 
 +
Pacman pode atualizar todos os pacotes no sistema com apenas um comando. Isso pode demorar um pouco dependendo de como anda a atualização do sistema. Este comando pode sincronizar as bases de dados do repositório '' e'' atualizar os pacotes do sistema (excluindo pacotes "locais" que não estão nos repositórios configurados):
 +
 
 +
# pacman -Syu
 +
 
 +
{{Dica | Em vez de logo que as atualizações estiverem disponíveis, os usuários devem reconhecer que, devido à natureza Arch's rolling release, uma atualização pode ter consequências imprevisíveis. Isso significa que não é prudente atualizar se, por exemplo, tem alguma tarefa importante para fazer. Preferencialmente, atualize durante o tempo livre e esteja preparado para lidar com quaisquer problemas que possam surgir.}}
 +
 
 +
Pacman é uma ferramenta de gerenciamento de pacotes poderosa, mas não tenta lidar com todos os casos. Leia [[The Arch Way (Português)]] se estiver confuso. Os usuários devem estar atentos e ter a responsabilidade pela manutenção do seu próprio sistema. '''Ao realizar uma atualização do sistema, é essencial que os usuários leiam todas as saídas de informações do pacman e usem o bom senso.''' Se um arquivo de configuração do modificado pelo usuário precisa ser atualizado para uma nova versão de um pacote, um arquivo {{ic |.pacnew}} será criado para evitar a substituição de configurações alteradas pelo usuário. Pacman pedirá ao usuário para juntá-las. Esses arquivos requerem intervenção manual do usuário e é uma boa prática para lidar com eles logo após cada atualização ou remoção do pacote. Veja [[Pacnew e arquivos Pacsave]] para mais informações.
 +
 
 +
{{Dica |Lembre-se que a saída do pacman é registrada no {{ic|/var/log/pacman.log}}.}}
 +
 
 +
Antes de atualizar, é aconselhável visitar [https://http://www.archlinux-br.org/ a página Arch Linux Brasil] para verificar as últimas notícias (alternativamente assinar o [http://www.archlinux-br.org/feeds/news/], [https://mailman.archlinux.org/mailman/listinfo/arch-announce/ arco-announce mailing list], ou seguir [https://twitter.com/archlinux @ archlinux] no Twitter), quando atualizações exigem a intervenção do usuário (mais do que isso pode ser tratada simplesmente seguindo as instruções dadas pelo pacman), uma mensagem de notícias no site será criada.
 +
 
 +
Se alguém encontrar problemas que não podem ser resolvidos por estas instruções, certifique-se de pesquisar no fórum. É provável que os outros já tenham encontrado o mesmo problema e publicaram as instruções para resolvê-lo.
 +
 
 +
=== Consultando bancos de dados do pacote ===
 +
 
 +
Pacman consulta o banco de dados do pacote local com a flag {{ic|-Q}}, veja:
 +
 
 +
$ pacman -Q --help
 +
 
 +
e consulte o bancos de dados de sincronização com a flag {{ic|-S}}, veja:
 +
 
 +
$ pacman -S --help
 +
 
 +
Pacman pode pesquisar por pacotes no banco de dados, pesquisando nomes e descrições dos pacotes:
 +
 
 +
$ pacman -Ss ''string1'' ''string2'' ...
 +
 
 +
Para procurar os pacotes já instalados:
 +
 
 +
$ pacman -Qs ''string1'' ''string2'' ...
 +
 
 +
Para exibir informações detalhadas sobre um determinado pacote:
 +
 
 +
$ pacman -Si ''package_name''
 +
 
 +
Para os pacotes instalados localmente:
 +
 
 +
$ pacman -Qi ''package_name''
 +
 
 +
Inserindo duas flags {{ic |-i}} também exibirá a lista de arquivos de backup e seus estados de alterações:
 +
 
 +
$ pacman -Qii ''package_name''
 +
 
 +
Para obter uma lista dos arquivos instalados por um pacote
 +
 
 +
$ pacman -Ql ''package_name''
 +
 
 +
Para pacotes não instalados, use [[pkgfile]].
 +
 
 +
Pode-se também consultar o banco de dados para saber qual pacote um arquivo no arquivo do sistema pertence:
 +
 
 +
$ pacman -Qo ''/path/to/file_name''
 +
 
 +
Para listar todos os pacotes não são exigidos como dependências (órfãos):
 +
 
 +
$ pacman -Qdt
 +
 
 +
Para listar a árvore de dependência de um pacote:
 +
 
 +
$ pactree ''package_name''
 +
 
 +
Para listar todos os pacotes dependentes de um pacote ''instalado'', use {{ic|whoneeds}} do pacote [[pkgtools]]:
 +
 
 +
$ whoneeds ''package_name''
 +
 
 +
=== Comandos adicionais ===
 +
 
 +
Atualizar o sistema e instalar uma lista de pacotes:
 +
 
 +
# pacman -Syu ''package_name1'' ''package_name2'' ...
 +
 
 +
Baixe um pacote sem instalá-lo:
 +
 
 +
# pacman -Sw ''package_name''
 +
 
 +
Instale um pacote 'local' que não é de um repositório remoto (ex., o pacote é do [[Arch User Repository (Português)]):
 +
 
 +
# pacman -U /path/to/package/package_name-version.pkg.tar.xz
 +
 
 +
{{Dica |Para manter uma cópia do pacote local no cache do pacman, use:
 +
# pacman -U file://path/to/package/package_name-version.pkg.tar.xz
 +
}}
 +
 
 +
Instalar um pacote 'remoto' (não de um repositório indicado nos arquivos de configuração do pacman):
 +
 
 +
# pacman -U <nowiki>http://www.example.com/repo/example.pkg.tar.xz</nowiki>
 +
 
 +
Limpe o cache de pacotes que não estão instalados ({{ic|/var/cache/pacman/pkg}}):
 +
 
 +
{{Dica | Só faça isso se tem certeza que os pacotes instalados são estáveis ​​e que o [[Downgrading Packages|downgrade]] não será necessário, já que removerá todas as versões anteriores da pasta cache, deixando apenas as versões dos pacotes que estão instalados atualmente. Tendo versões mais antigas de pacote vem a calhar no caso de uma futura atualização provocar um erro.}}
 +
 
 +
# pacman -Sc
 +
 
 +
Limpe o cache do pacote inteiro:
 +
 
 +
{{Dica | Este limpa todo o cache de pacote. Fazer isso é considerado uma má prática, que evita a possibilidade de downgrade de alguma coisa diretamente da pasta cache. Os usuários serão forçados a ter que usar uma fonte alternativa de pacotes obsoletos tais como o [[Downgrading Packages#ARM|Arch Rollback Machine]].}}
 +
 
 +
# pacman -Scc
 +
 
 +
{{Dica | Como alternativa tanto para o {{ic|-Sc}} e {{ic|-Scc}}, considere usar {{ic|paccache}} do {{pkg|pacman}}. Isso oferece mais controle sobre o que e quantos pacotes são apagados. Execute {{ic|paccache -h}} para obter instruções.}}
 +
 
 +
=== Atualizações parciais não são suportadas ===
 +
 
 +
Arch é um rolling release, e novas versões de [[Wikipedia:Library (computing)|bibliotecas]] serão colocadas nos repositórios.  Os desenvolvedores e usuários confiáveis reconstruirão todos os pacotes nos repositórios que precisam ser reconstruídos com as bibliotecas. Se o sistema tem pacotes instalados localmente (tal como pacotes [[Arch User Repository (Português)]), os usuários deverão recontruí-los quando suas dependências receberem uma colisão [[Wikipedia:soname|soname]].
 +
 
 +
Isso significa que as atualizações parciais são '''não suportadas'''. Não use {{ic|pacman -Sy package}} ou equivalente como {{ic|pacman -Sy}} e depois {{ic|pacman -S package}}. Sempre atualize antes de instalar um pacote -- especialmente se o pacman atualizou as sincronização de repositórios. Tenha muito cuidado ao usar {{ic|IgnorePkg}} e {{ic|IgnoreGroup}}, pelo mesmo motivo.
 +
 
 +
Se um cenário de atualização parcial foi criado e os binários estão quebrados porque não conseguem encontrar as bibliotecas que estão ligadas, '''não "conserte" o problema simplesmente pelo symlinking'''. Bibliotecas recebem colisões [[Wikipedia:soname|soname]] quando elas '''não são compatíveis'''. Um simples {{ic|pacman -Syu}} para um espelho devidamente sincronizado resolverá o problema, desde que pacman não esteja quebrado.
 +
 
 +
== Solução de problemas ==
 +
 
 +
{{FAQ
 +
|question=Uma atualização para o pacote XYZ quebrou meu sistema!
 +
|answer=Arch Linux é uma distribuição de ponta rolling-release. Atualizações de pacotes disponíveis assim que são considerados estáveis ​​o suficiente para uso geral. No entanto, as atualizações, por vezes, exigem a intervenção do usuário: arquivos de configuração podem precisar ser atualizados, dependências opcionais podem alterar, etc.
 +
 
 +
A dica mais importante para se lembrar é não "às cegas" atualizar o sistema Arch. Sempre leia a lista de pacotes a serem atualizados. Note se os pacotes "críticos" vão ser atualizados ({{Pkg|linux}}, {{Pkg|xorg-server}}, e assim por diante). Se assim for, é geralmente uma boa idéia verificar se há alguma notícia no  http://www.archlinux-br.org/ e verifique as mensagens mais recentes no fórum para ver se as pessoas estão enfrentando problemas com o resultado de uma atualização.
 +
 
 +
Se uma atualização do pacote é esperada/conhecida por causar de problemas, empacotadores garantirão que pacman exiba uma mensagem apropriada quando o pacote é atualizado. Se enfrentar problemas após uma atualização, verifique a saída do pacman, veja o log ({{ic|/var/log/pacman.log}}).
 +
 
 +
Neste ponto, '''só depois de garantir que não há nenhuma informação disponível através de pacman, não há nenhuma notícia relativa em http://www.archlinux-br.org/, e não há mensagem no fórum sobre a atualização''', considere a busca de ajuda no fórum, através [[IRC Channel|IRC]], ou [[Downgrading Packages|downgrade do pacote problemático]].}}
 +
 
 +
{{FAQ
 +
|question=Eu sei que uma atualização para o pacote ABC foi lançada, mas pacman diz que o meu sistema está atualizado!
 +
|answer=Espelhos do Pacman não são sincronizados imediatamente. Pode demorar mais de 24 horas antes que uma atualização esteja disponível para você. As únicas opções é ser paciente ou usar outro espelho. [https://www.archlinux.org/mirrors/status/ MirrorStatus] pode ajudar a identificar um espelho atualizado.}}
 +
 
 +
{{FAQ
 +
|question=Eu recebo um erro durante a atualização: "o arquivo já existe no sistema de arquivos"!
 +
|answer=ASIDE: ''Tirado de https://bbs.archlinux.org/viewtopic.php?id=56373 by Misfit138.''
 +
 
 +
error: could not prepare transaction
 +
error: failed to commit transaction (conflicting files)
 +
package: /path/to/file exists in filesystem
 +
Errors occurred, no packages were upgraded.
 +
 
 +
Por que isso está acontecendo: pacman detectou um conflito de arquivo, e pelo projeto, não vai substituir os arquivos para você. Esta é uma característica do projeto, e não um defeito.
 +
 
 +
O problema é usualmente simples de se resolver. Uma maneira segura é primeiro verificar se outro pacote possui o arquivo ({{ic|pacman -Qo /path/to/file}}). Se o arquivo é de propriedade de outro pacote, [[Reporting Bug Guidelines|enviar relatório de bug]]. Se o arquivo não é propriedade de outro pacote, renomeie o 'existente no sistema de arquivo' e re-execute o comando atualizar. Se tudo correr bem, o arquivo pode então ser removido.
 +
 
 +
Se você tinha instalado um programa manualmente, sem usar pacman ou interface, você tem que removê-lo e todos os seus arquivos e reinstalar corretamente usando pacman.
 +
 
 +
Cada pacote instalado fornece arquivo {{ic|/var/lib/pacman/local/$package-$version/files}} que contém metadata sobre este pacote. Se este arquivo for corrompido - é vazio ou ausente - que resulta no erro "o arquivo existe no sistema de arquivos" durante a atualização do pacote. Esse erro geralmente só diz respeito a um único pacote e, em vez de renomear manualmente e depois remover todos os arquivos que pertencem ao pacote em questão, você pode executar {{ic|pacman -S --force $package}} para forçar o pacman substituir estes arquivos
 +
 
 +
'''Não''' execute {{ic|pacman -Syu --force}}.}}
 +
 
 +
{{FAQ
 +
|question=Eu recebo um erro ao instalar um pacote: "não econtrou em sincronia com banco de dados"
 +
|answer=Primeiramente, verifique se o pacote realmente existe (e fique atento para os erros de digitação!). Se o determinado pacote existe sua lista de pacotes pode estar desatualizada ou seus repositórios podem estar configurados incorretamente. Tente executar {{ic | pacman-Syy.}} para forçar uma atualização de todas as listas de pacotes}}
 +
 
 +
{{FAQ
 +
|question=Eu recebo um erro ao instalar um pacote: "alvo não foi encontrado"
 +
|answer=Primeiramente, verifique se o pacote realmente existe (e fique atento para os erros de digitação!). Se o determinado pacote existe sua lista de pacotes pode estar desatualizada ou seus repositórios podem estar configurados incorretamente. Tente executar {{ic | pacman-Syy}} para forçar uma atualização de todas as listas de pacotes. <br>Pode ser também que o repositório que contém o pacote não está ativado em seu sistema, por exemplo, o pacote poderia estar no repositório ''multilib'', mas ''multilib'' não está habilitado em seu ''pacman.conf''.}}
 +
 
 +
{{FAQ
 +
|question=Pacman está atualizando várias vezes o mesmo pacote!
 +
|answer=É devido a entradas duplicadas em {{ic|/var/lib/pacman/local/}}, tal como duas instâncias {{ic|linux}}. {{ic|pacman -Qi}} emite a versão correta, mas {{ic|pacman -Qu}} reconhece a versão antiga e, portanto, tentará atualizar.
 +
 
 +
Solução: eliminar a entrada em {{ic|/var/lib/pacman/local/}}.
 +
 
 +
{{Nota |A versão 3.4 do pacman deveria exibir um erro de entradas duplicadas, que deveria deixar esta nota obsoleta.}}}}
 +
 
 +
{{FAQ
 +
|question=Pacman falha durante uma atualização!
 +
|answer=No caso de colisão do pacman com um erro de "escrita de banco de dados" equanto remove um pacote, e falha ao reinstalar ou atualizar pacotes:
 +
 
 +
# Inicialize usando a mídia de instalação do Arch
 +
# Monte seu sistema de arquivos root.
 +
# Atualize o banco de dados do pacman via {{ic|pacman -Syy}}.
 +
# Reinstale o pacote quebrado via {{ic|pacman -r /path/to/root -S package}}.}}
 +
 
 +
{{FAQ
 +
|question=Eu instalei programa usando "make install"; esses arquivos não pertencem a nenhum pacote!
 +
|answer=Se receber um erro "arquivos conflitantes", note que o pacman substituirá manualmente o progarama instalado se adicionar com o {{ic|--force}}, por exemplo,({{ic|pacman -S --force}}). Veja [[Pacman Tips#Identify files not owned by any package]] para um script que procura o arquivo de sistema por arquivos ''rejeitados''.
 +
{{Aviso |Tome cuidado ao usar a opção {{ic|--force}}, pois pode causar problemas graves se usada indevidamente. Recomenda-se usar esta opção apenas quando for requisitada em Arch notícias.}}}}
 +
 
 +
{{FAQ
 +
|question=Preciso de um pacote com um arquivo específico. Como faço para saber o que ele dispõe?
 +
|answer=Instale [[pkgfile]] que usa um banco de dados separado com todos os arquivos e seus pacotes associados.}}
 +
 
 +
{{FAQ
 +
|question=Pacman está completamente quebrado! Como faço para reinstalá-lo?
 +
|answer=No caso de pacman está quebrado sem possibilidade de reparo, baixe manualmente os pacotes necessários ({{Pkg|openssl}}, {{Pkg|libarchive}}, e {{Pkg|pacman}}) e extraia eles no root. O binário pacman será restaurado juntamente com seu arquivo de configuração padrão. Depois disso, reinstale esses pacotes com pacman para manter a integridade do banco de dados do pacote. Informações adicionais e um exemplo de script (desatualizado) que automatiza o processo está disponível nesta [https://bbs.archlinux.org/viewtopic.php?id=95007] mensagem.}}
 +
 
 +
{{FAQ
 +
|question=Depois de atualizar meu sistema, eu recebo um erro "não é possível encontrar o dispositivo root" depois de reiniciar e o meu sistema não mais inicializará.
 +
|answer=Muito provavelmente seus initramfs quebrou durante uma atualização do kernel (uso indevido da opção do pacman {{ic|--force}} pode ser uma causa). Você tem duas opções:
 +
 
 +
'''1.''' Tente a entrada ''Fallback''.
 +
 
 +
: {{Dica |No caso de você ter removido esta entrada por alguma razão, você pode sempre pressionar a tecla {{Keypress|Tab}} quando o gerenciador de boot aparecer (para Syslinux) ou {{Keypress|e}} (para GRUB), renomear {{ic|initramfs-linux-fallback.img}} e pressione {{Keypress|Enter}} ou {{Keypress|b}} (dependendo do seu gerenciador de boot) para inicializar com os novos parâmetros.}}
 +
 
 +
: Quando o sistema iniciar, execute este comando (para amarzenar no Kernel {{Pkg|linux}}) através do console ou de um terminal para reconstruir a imagem initramfs:
 +
 
 +
: {{bc|# mkinitcpio -p linux}}
 +
 
 +
'''2.''' Se não funcionar, de um lançamento 2012 Arch (CD/DVD ou USB), execute:
 +
 
 +
: {{Nota |Se você não tem uma versão de 2012 ou se tem apenas alguma outra distribuição Linux "live" que possa aplicar [[chroot]] usando o jeito antigo. Obviamente, não será mais simples que digitando o script {{ic|arch-chroot}}.}}
 +
 
 +
: {{bc|<nowiki>
 +
# mount /dev/sdxY /mnt        #Sua partição root.
 +
# mount /dev/sdxZ /mnt/boot    #Se usa uma partição /boot separada.
 +
# arch-chroot /mnt
 +
# pacman -Syu mkinitcpio systemd linux</nowiki>}}
 +
 
 +
: Reinstalando o Kernel (o pacote {{Pkg|linux}}) irá gerar automaticamente a imagem com {{ic|mkinitcpio -p linux}}. Não precisa fazer separamente.
 +
 
 +
: Depois, recomenda-se que você execute {{ic|exit}}, {{ic|umount /mnt/{boot,} }} e {{ic|reboot}}.
 +
 
 +
: {{Nota |Se você não pode entrar no ambiente arch-chroot ou chroot, mas precisa reintalar os pacotes você pode usar o comando {{ic|pacman -r /mnt -Syu foo bar}} para utilizar pacman em sua partição root.}}}}
 +
 
 +
{{FAQ
 +
|question=Assinatura de "Usuário <email@gmail.com>" e de confiança desconhecida, falha na instalação
 +
|answer=Siga [[pacman-key#Resetting all the keys]]. Ou pode tentar atualizar manualmente {{Pkg|archlinux-keyring}} primeiro o pacote, ex. {{ic|pacman -S archlinux-keyring}}. }}
 +
 
 +
{{FAQ
 +
|question=Recebo
 +
:error: PackageName: assinatura do "User <email@archlinux.org>" é inválida
 +
:error: falha ao confirmar a transação (pacote inválido ou corrompido (PGP signature))
 +
:Erros ocorreram, nenhum pacote foi atualizado.
 +
|answer=Isso acontece quando o relógio do sistema está errado. Ajuste a [[time|hora]] e execute: {{bc|# hwclock -w}} antes de tentar instalar/atualizar um pacote novamente.}}
 +
 
 +
{{FAQ
 +
|question=Recebo um erro "falha ao confirmar a transação (pacote inválido ou corrompido)"
 +
|answer=Procure por arquivos {{ic|*.part}} (pacotes baixados parcialmente) em {{ic|/var/cache/pacman/pkg}} e remove eles (muitas vezes causado pelo uso da opção {{ic|XferCommand}} em {{ic|pacman.conf}}).}}
 +
 
 +
{{FAQ
 +
|question=Recebo erro toda vez que uso pacman dizendo 'aviso: locale atual é inválida; usando padrão locale "C"'. O que eu faço?
 +
|answer=Como a própria mensagem de erro diz, sua locale está configurada incorretamente. Consulte [[Locale]].}}
  
'''nota''' Algum cuidado tem que ser tomando quando utilizar os repositório '''testing'''
+
{{FAQ
 +
|question=Como posso ter Pacman para minhas configurações de proxy?
 +
|answer=Certifique-se que as variáveis de ambiente relevantes ({{ic|$http_proxy}}, {{ic|$ftp_proxy}} etc.) estão configuradas. Se você usa Pacman com [[sudo]], você precisa configurar o sudo para [[sudo#Environment variables|passar essas variáveis ​​de ambiente para o Pacman]].
 +
}}
  
===Erros===
+
{{FAQ
 +
|question=Como faço para reinstalar todos os pacotes, mantendo informações sobre se algo foi explicitamente instalado ou como uma dependência??
 +
|answer=Para reinstalar todos os pacotes nativos:: {{ic|pacman -S $(pacman -Qnq)}} (a opção {{ic|-S}} preserva a razão de instalação por padrão). <br> Então você terá que reinstalar todos os pacotes externos, que podem ser listados com {{ic|pacman -Qmq}}.
 +
}}
  
Se obteve o seguinte erro
+
== Veja também ==
'''not found in sync db'''
+
é porque o pacote não foi encontrado visto o repositório não ter sido definido correctamente.
+
  
==Links Relacionados==
+
* [[Common Applications/Utilities#Package management]]
* [[Improve Pacman Performance]]
+
* [[Colored Pacman output]]
+
* [[Downgrade packages]]
+
* [[Redownloading all installed packages]]
+
* [[Arch User Repository]]
+
* [[Local repository HOW-TO]]
+
* [[Custom local repository with ABS and gensync]]
+
* [[Howto Upgrade via Home Network]] (Network Shared Pacman Cache)
+
* [[rucksack]]
+
* [[Pacman GUI Frontends]]
+
* [[Pacman_Aliases|Pacman Aliases (for bash)]]
+

Revision as of 03:12, 15 August 2013

Package management (Português)

Sumário help replacing me
Pacman é o gerenciador de pacotes do Arch Linux. Gerenciadores de pacotes são usados para instalar, atualizar e remover programas. Este artigo aborda o uso básico com dicas e solução de problemas.
Visão Geral
Os Pacotes no Arch Linux são construídos usando o makepkg e um script de construção personalizado para cada pacote (conhecido como PKGBUILD). Uma vez empacotado, o programa pode ser instalado e gerenciado com o pacman. PKGBUILDs para software nos repositórios oficiais são disponíves na árvore do ABS; mais de milhares estão disponíveis no (não suportado) Arch User Repository.
Relacionado
Downgrading Packages
Improve Pacman Performance
Pacman GUI Frontends
Pacman Rosetta
Pacman Tips
Pacman package signing
FAQ#Package Management
pacman-key
Pacnew and Pacsave Files
Recursos
libalpm(3) Manual Page
pacman(8) Manual Page
pacman.conf(5) Manual Page
repo-add(8) Manual Page

O gerenciador de pacote pacman é uma das grandes vantagens do Arch Linux. Combina um simples pacote no formato binário, com um fácil uso de sistema de compilação. A meta do pacman é tornar o mais fácil possivel gerenciar pacotes, sejam eles dos oficiais repositórios Arch ou das próprias compilações do usuário.

Pacman mantém o sistema atualizado, listas de pacotes de sincronização com o servidor mestre. Este modelo servidor/cliente também permite o usuário baixar/instalar pacotes com um simples comando, completo com todas as dependências requeridas.

Pacman é escrito na linguagem de programação C e usa o formato de pacote .pkg.tar.xz.

Dica: O oficial pacote pacman também contém outras ferramentas úteis, tais como o makepkg, pactree, vercmp e mais: executa pacman -Ql pacman | grep bin para ver uma lista completa.

Configuração

Os ajustes do Pacman estão localizados em /etc/pacman.conf. Este é o local onde o usuário configura o programa para funcionar da forma desejada. Informações detalhadas sobre o arquivo de configuração pode ser encontrada em man pacman.conf.

Opções gerais

Opções gerais estão na seção [options]. Leia a página de manual ou olhe no padrão pacman.conf para obter informações sobre o que pode ser feito aqui.

Pular pacotes para não serem atualizados

Para pular a atualização de um pacote específico, faça:

IgnorePkg=linux

Para vários pacotes use uma lista separada por espaço, ou use adicionais linhas IgnorePkg.

Pular um grupos de pacotes para não serem atualizados

Tal como acontece com os pacotes, pular um grupo de pacote inteiro também é possível:

IgnoreGroup=gnome

Pular arquivos para não serem instalados no sistema

Para pular sempre a instalação de lista de diretórios sob NoExtract. Por exemplo, para evitar a instalação de units systemd use:

NoExtract=usr/lib/systemd/system/*

Repositórios

A seção define quais repositórios usar, como referido no /etc/pacman.conf. Podem ser mencionados aqui diretamente ou incluídos de outro arquivo (como /etc/pacman.d/mirrorlist), tornando-se assim necessário manter apenas uma lista. Veja aqui para configuração de espelho.

/etc/pacman.conf
#[testing]
#SigLevel = PackageRequired
#Include = /etc/pacman.d/mirrorlist

[core]
SigLevel = PackageRequired
Include = /etc/pacman.d/mirrorlist

[extra]
SigLevel = PackageRequired
Include = /etc/pacman.d/mirrorlist

#[community-testing]
#SigLevel = PackageRequired
#Include = /etc/pacman.d/mirrorlist

[community]
SigLevel = PackageRequired
Include = /etc/pacman.d/mirrorlist

# If you want to run 32 bit applications on your x86_64 system,
# enable the multilib repositories as required here.

#[multilib-testing]
#SigLevel = PackageRequired
#Include = /etc/pacman.d/mirrorlist

#[multilib]
#SigLevel = PackageRequired
#Include = /etc/pacman.d/mirrorlist

# An example of a custom package repository.  See the pacman manpage for
# tips on creating your own repositories.
#[custom]
#SigLevel = Optional TrustAll
#Server = file:///home/custompkgs

Cuidados devem ser tomados ao usar o repositório [testing]. Ele está em desenvolvimento ativo e a atualização pode fazer que alguns pacotes parem de funcionar. As pessoas que usam o repositório [testing] são encorajadas a se increver em arch-dev-public mailing list para obter informações atualizadas.}}

Segurança de pacotes

Pacman suporta 4 assinaturas de pacotes, que adiciona um nível extra de segurança para os pacotes. A configuração padrão, SigLevel = Required DatabaseOptional, habilita a verificação de assinaturas para todos os pacotes em um nível global: este pode ser substituido por linhas por repositório SigLevel, como mostrado acima. Para mais detalhes sobre pacote de assinatura e verificação de assinatura, dê uma olhada em pacman-key.

Uso

O que se segue é apenas uma pequena amostra das operações que o pacman pode executar. Para ler mais exemplos, consulte man pacman. Para uma introdução, veja pacman - An Introduction.

Instalando Pacotes

Instalando Pacotes especificos

Para instalar um único pacote ou lista de pacotes (incluindo dependências), execute o seguinte comando:

# pacman -S package_name1 package_name2 ...

Às vezes, há várias versões de um pacote nos diferentes repositórios, por exemplo [extra] e [testing]. Para instalar a versão anterior, o repositṕorio deve ser definido na frente:

# pacman -S extra/package_name

Instalando grupos de pacotes

Alguns pacotes pertencem a um grupo de pacotes que podem ser instalados simultaneamente. Por exemplo, o comando:

# pacman -S gnome

este comando solicitará que você selecione os pacotes do grupo gnome que você deseja instalar.

Às vezes, um grupo de pacote conterá uma grande quantidade de pacotes, e pode haver só alguns que você quer ou não instalar. Em vez de digitar todos os números, exceto aqueles que você não quer, pode ser mais conveniente selecionar ou excluir pacotes ou intervalos de pacotes com a seguinte sintaxe:

Digite uma seleção (padrão=todos): 1-10 15

irá selecionar pacotes 1 até 10 e 15 para a instalação, ou:

Digite uma seleção (padrão=todos):: ^5-8 ^2

irá selecionar todos os pacotes, exceto 5 até 8 e 2 para a instalação.

Para ver quais pacotes pertencem ao grupo gnome, execute:

# pacman -Sg gnome

Também visite https://www.archlinux.org/groups/ para saber quais os grupos de pacotes disponíveis.

Nota: Se um pacote na lista já está instalado no sistema, ele será reinstalado mesmo se já estiver atualizado. Este comportamento pode ser substituído com a opção --needed.
Dica: Ao instalar os pacotes, não atualiza a lista de pacotes sem atualização do sistema (ex. pacman -Sy package_name), isso pode ocasinar erros de dependêcias. Veja #Partial upgrades are unsupported e https://bbs.archlinux.org/viewtopic.php?id=89328.

Removendo pacotes

Para remover um único pacote, deixando todas as suas dependências instaladas:

# pacman -R package_name

Para remover um pacote e suas dependências que não são exigidas por qualquer outro pacote instalado:

# pacman -Rs package_name

Para remover um pacote, suas dependências e todos os pacotes que dependem deste pacote:

Dica: Esta operação é recursiva, e deve ser usada com cuidado, pois pode remover muitos pacotes potencialmente necessários.
# pacman -Rsc package_name

Para remover um pacote, o qual é exigido por outro pacote, sem remover o pacote dependente:

# pacman -Rdd package_name

O pacman salva arquivos de configuração importantes ao remover certos aplicativos e os nomes com a extensão: .pacsave. Para prevenir a criação desses arquivos de backup use a opção -n:

# pacman -Rn package_name
Nota: Pacman não removerá as configurações que o próprio aplicativo cria (por exemplo, "dotfiles" na pasta home).

Atualizando pacotes

Pacman pode atualizar todos os pacotes no sistema com apenas um comando. Isso pode demorar um pouco dependendo de como anda a atualização do sistema. Este comando pode sincronizar as bases de dados do repositório e atualizar os pacotes do sistema (excluindo pacotes "locais" que não estão nos repositórios configurados):

# pacman -Syu
Dica: Em vez de logo que as atualizações estiverem disponíveis, os usuários devem reconhecer que, devido à natureza Arch's rolling release, uma atualização pode ter consequências imprevisíveis. Isso significa que não é prudente atualizar se, por exemplo, tem alguma tarefa importante para fazer. Preferencialmente, atualize durante o tempo livre e esteja preparado para lidar com quaisquer problemas que possam surgir.

Pacman é uma ferramenta de gerenciamento de pacotes poderosa, mas não tenta lidar com todos os casos. Leia The Arch Way (Português) se estiver confuso. Os usuários devem estar atentos e ter a responsabilidade pela manutenção do seu próprio sistema. Ao realizar uma atualização do sistema, é essencial que os usuários leiam todas as saídas de informações do pacman e usem o bom senso. Se um arquivo de configuração do modificado pelo usuário precisa ser atualizado para uma nova versão de um pacote, um arquivo .pacnew será criado para evitar a substituição de configurações alteradas pelo usuário. Pacman pedirá ao usuário para juntá-las. Esses arquivos requerem intervenção manual do usuário e é uma boa prática para lidar com eles logo após cada atualização ou remoção do pacote. Veja Pacnew e arquivos Pacsave para mais informações.

Dica: Lembre-se que a saída do pacman é registrada no /var/log/pacman.log.

Antes de atualizar, é aconselhável visitar a página Arch Linux Brasil para verificar as últimas notícias (alternativamente assinar o [1], arco-announce mailing list, ou seguir @ archlinux no Twitter), quando atualizações exigem a intervenção do usuário (mais do que isso pode ser tratada simplesmente seguindo as instruções dadas pelo pacman), uma mensagem de notícias no site será criada.

Se alguém encontrar problemas que não podem ser resolvidos por estas instruções, certifique-se de pesquisar no fórum. É provável que os outros já tenham encontrado o mesmo problema e publicaram as instruções para resolvê-lo.

Consultando bancos de dados do pacote

Pacman consulta o banco de dados do pacote local com a flag -Q, veja:

$ pacman -Q --help

e consulte o bancos de dados de sincronização com a flag -S, veja:

$ pacman -S --help

Pacman pode pesquisar por pacotes no banco de dados, pesquisando nomes e descrições dos pacotes:

$ pacman -Ss string1 string2 ...

Para procurar os pacotes já instalados:

$ pacman -Qs string1 string2 ...

Para exibir informações detalhadas sobre um determinado pacote:

$ pacman -Si package_name

Para os pacotes instalados localmente:

$ pacman -Qi package_name

Inserindo duas flags -i também exibirá a lista de arquivos de backup e seus estados de alterações:

$ pacman -Qii package_name

Para obter uma lista dos arquivos instalados por um pacote

$ pacman -Ql package_name

Para pacotes não instalados, use pkgfile.

Pode-se também consultar o banco de dados para saber qual pacote um arquivo no arquivo do sistema pertence:

$ pacman -Qo /path/to/file_name

Para listar todos os pacotes não são exigidos como dependências (órfãos):

$ pacman -Qdt

Para listar a árvore de dependência de um pacote:

$ pactree package_name

Para listar todos os pacotes dependentes de um pacote instalado, use whoneeds do pacote pkgtools:

$ whoneeds package_name

Comandos adicionais

Atualizar o sistema e instalar uma lista de pacotes:

# pacman -Syu package_name1 package_name2 ...

Baixe um pacote sem instalá-lo:

# pacman -Sw package_name

Instale um pacote 'local' que não é de um repositório remoto (ex., o pacote é do [[Arch User Repository (Português)]):

# pacman -U /path/to/package/package_name-version.pkg.tar.xz
Dica: Para manter uma cópia do pacote local no cache do pacman, use:
# pacman -U file://path/to/package/package_name-version.pkg.tar.xz

Instalar um pacote 'remoto' (não de um repositório indicado nos arquivos de configuração do pacman):

# pacman -U http://www.example.com/repo/example.pkg.tar.xz

Limpe o cache de pacotes que não estão instalados (/var/cache/pacman/pkg):

Dica: Só faça isso se tem certeza que os pacotes instalados são estáveis ​​e que o downgrade não será necessário, já que removerá todas as versões anteriores da pasta cache, deixando apenas as versões dos pacotes que estão instalados atualmente. Tendo versões mais antigas de pacote vem a calhar no caso de uma futura atualização provocar um erro.
# pacman -Sc

Limpe o cache do pacote inteiro:

Dica: Este limpa todo o cache de pacote. Fazer isso é considerado uma má prática, que evita a possibilidade de downgrade de alguma coisa diretamente da pasta cache. Os usuários serão forçados a ter que usar uma fonte alternativa de pacotes obsoletos tais como o Arch Rollback Machine.
# pacman -Scc
Dica: Como alternativa tanto para o -Sc e -Scc, considere usar paccache do pacman. Isso oferece mais controle sobre o que e quantos pacotes são apagados. Execute paccache -h para obter instruções.

Atualizações parciais não são suportadas

Arch é um rolling release, e novas versões de bibliotecas serão colocadas nos repositórios. Os desenvolvedores e usuários confiáveis reconstruirão todos os pacotes nos repositórios que precisam ser reconstruídos com as bibliotecas. Se o sistema tem pacotes instalados localmente (tal como pacotes [[Arch User Repository (Português)]), os usuários deverão recontruí-los quando suas dependências receberem uma colisão soname.

Isso significa que as atualizações parciais são não suportadas. Não use pacman -Sy package ou equivalente como pacman -Sy e depois pacman -S package. Sempre atualize antes de instalar um pacote -- especialmente se o pacman atualizou as sincronização de repositórios. Tenha muito cuidado ao usar IgnorePkg e IgnoreGroup, pelo mesmo motivo.

Se um cenário de atualização parcial foi criado e os binários estão quebrados porque não conseguem encontrar as bibliotecas que estão ligadas, não "conserte" o problema simplesmente pelo symlinking. Bibliotecas recebem colisões soname quando elas não são compatíveis. Um simples pacman -Syu para um espelho devidamente sincronizado resolverá o problema, desde que pacman não esteja quebrado.

Solução de problemas

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Template:FAQ

Veja também