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

From ArchWiki
Jump to: navigation, search
(Repositórios)
(24 intermediate revisions by 10 users not shown)
Line 1: Line 1:
[[Category:Gestão de pacotes (Português de Portugal)]]
+
{{Lowercase title}}
[[Category:Ferramentas (Português de Portugal)]]
+
[[Category:Package management (Português)]]
[[Category:HOWTOs (Português de Portugal)]]
+
[[ar:Pacman]]
 +
[[cs:Pacman]]
 +
[[da:Pacman]]
 +
[[de:Pacman]]
 +
[[el:Pacman]]
 +
[[es:Pacman]]
 +
[[en:Pacman]]
 +
[[fr:Pacman]]
 +
[[id:Pacman]]
 +
[[it:Pacman]]
 +
[[ja:Pacman]]
 +
[[ko:Pacman]]
 +
[[lt:Pacman]]
 +
[[nl:Pacman]]
 +
[[pl:Pacman]]
 +
[[pt:Pacman]]
 +
[[ro:Pacman]]
 +
[[ru:Pacman]]
 +
[[sr:Pacman]]
 +
[[sv:Pacman]]
 +
[[tr:pacman]]
 +
[[uk:Pacman]]
 +
[[zh-CN:Pacman]]
 +
[[zh-TW:Pacman]]
 +
{{Article summary start| Sumário}}
 +
{{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.}}
 +
{{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}}
  
{{i18n_links_start}}
+
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.
{{i18n_entry|Česky|:Pacman (Česky)}}
+
{{i18n_entry|Deutsch|:Pacman (Deutsch)}}
+
{{i18n_entry|English|:Pacman}}
+
{{i18n_entry|Español|:Pacman (Español)}}
+
{{i18n_entry|Français|:Pacman (Français)}}
+
{{i18n_entry|Italiano|:Pacman (Italiano)}}
+
{{i18n_entry|Nederlands|:Pacman (Nederlands)}}
+
{{i18n_entry|Polski|:Pacman (Polski)}}
+
{{i18n_entry|Português de Portugal|:Pacman (Portugues)}}
+
{{i18n_entry|Romanian|:Pacman (română)}}
+
{{i18n_entry|Русский|:Pacman (Русский)}}
+
{{i18n_entry|简体中文|:Pacman (简体中文)}}
+
{{i18n_entry|한국어|:Pacman (한국어)}}
+
{{i18n_links_end}}
+
  
==Descrição==
+
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.
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.
+
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).
+
  
==Utilização==
+
Pacman é escrito na linguagem de programação C e usa o formato de pacote {{ic|.pkg.tar.xz}}.
  
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.
+
{{Dica |O oficial pacote {{Pkg|pacman}} também contém outras ferramentas úteis, tais como o '''makepkg''', '''pactree''', '''vercmp''' e mais: execute {{ic|pacman -Ql pacman <nowiki>|</nowiki> grep bin}} para ver uma lista completa.}}
  
===Instalar e Remover Pacotes===
+
== Configuração ==
Antes de instalar e actualizar pacotes, é bom sincronizar a lista local de pacotes com a dos repositórios.
+
  
pacman -Sy
+
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].
  
ou
+
=== Opções gerais ===
  
pacman --sync --refresh
+
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.
  
Para instalar ou actualizar apenas um pacote ou uma lista de pacotes (incluindo dependencias) siga o seguinte comando:
+
==== Pular pacotes para não serem atualizados ====
  
pacman -S nome_pacote1 nome_pacote2
+
Para pular a atualização de um pacote específico, faça:
  
Por vezes há mais versões de um pacote em diferentes repositórios (ex: extra e testing). Pode especificar qual deles instalar:
+
  IgnorePkg=linux
  
pacman -S extra/nome_pacote
+
Para vários pacotes use uma lista separada por espaço, ou use adicionais linhas {{ic|IgnorePkg}}.
pacman -S testing/nome_pacote
+
  
Pode também actualizar a lista de pacotes quando for instalar um pacote:
+
==== Pular um grupos de pacotes para não serem atualizados ====
  
pacman -Sy nome_pacote
+
Tal como acontece com os pacotes, pular um grupo de pacote inteiro também é possível:
  
Para remover um pacote, deixando todas as dependências instaladas:
+
IgnoreGroup=gnome
  
pacman -R nome_pacote
+
==== Pular arquivos para não serem instalados no sistema ====
  
Para remover todas as dependências de um pacote que não estão a ser utilizadas por nenhum outro:
+
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:
  
  pacman -Rs nome_pacote
+
  NoExtract=usr/lib/systemd/system/*
  
Para remover um pacote sem verificar as suas dependências:
+
=== Repositórios ===
  
pacman -Rd nome_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.
  
===Actualizar o Sistema===
+
{{hc|/etc/pacman.conf|2=
 +
#[testing]
 +
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
O '''Pacman''' pode actualizar todos os pacotes do sistema com apenas um comando. Isto pode demorar algum tempo dependendo do quanto o sistema está actualizado.
+
[core]
 +
SigLevel = PackageRequired
 +
Include = /etc/pacman.d/mirrorlist
  
pacman -Su
+
[extra]
 +
SigLevel = PackageRequired
 +
Include = /etc/pacman.d/mirrorlist
  
Contudo, a melhor opção é sincronizar a lista de pacotes local com a do repositório e actualizar o sistema:
+
#[community-testing]
 +
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
pacman -Syu
+
[community]
 +
SigLevel = PackageRequired
 +
Include = /etc/pacman.d/mirrorlist
  
===Fazer Query à Base de Dados de Pacotes===
+
# If you want to run 32 bit applications on your x86_64 system,
 +
# enable the multilib repositories as required here.
  
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):
+
#[multilib-testing]
 +
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
pacman -Ss pacote
+
#[multilib]
 +
#SigLevel = PackageRequired
 +
#Include = /etc/pacman.d/mirrorlist
  
Para procurar os pacotes instalados:
+
# 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 -Qs pacote
+
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.}}
  
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.
+
=== Segurança de pacotes ===
  
  pacman -Si pacote
+
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 -Qi pacote
+
  
Para uma lista dos ficheiros que estão num pacote:
+
== Uso ==
  
pacman -Ql pacote
+
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]].
  
Para uma lista dos ficheiros que já não estão em uso por nenhum pacote instalado:
+
=== Instalando Pacotes ===
  
pacman -Qe
+
==== Instalando Pacotes especificos ====
  
Pode também fazer um ''query'' sobre a qual pacote pertence um ficheiro presente no sistema.
+
Para instalar um único pacote ou lista de pacotes (incluindo dependências), execute o seguinte comando:
  
  pacman -Qo /caminho/do/ficheiro
+
  # pacman -S ''package_name1'' ''package_name2'' ...
  
===Outros usos===
+
À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:
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 -S extra/''package_name''
  pacman -U /caminho/do/pacote/nome_pacote-versão.pkg.tar.gz
+
  
* Apagar a ''cache'' de pacotes (/var/cache/pacman/pkg):
+
==== Instalando grupos de pacotes ====
pacman -Scc
+
  
Para mais informação detalhada fazer <code>pacman --help</code> ou <code>man pacman</code>
+
Alguns pacotes pertencem a um grupo de pacotes que podem ser instalados simultaneamente. Por exemplo, o comando:
  
==Configuração==
+
# pacman -S gnome
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===
+
este comando solicitará que você selecione os pacotes do grupo {{Grp|gnome}} que você deseja instalar.
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===
+
À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:
Nesta secção pode definir quais os repositórios a utilizar, como referido em ''/etc/pacman.conf'' que está localizado em ''/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 ''/etc/pacman.d/'', sendo eles '''community''', '''core''', '''extra''', '''release''', '''testing''' e '''unstable'''. It is important to edit each one to include the repositories you require.  The following is an example for the official repositories which have a lot of [[mirrors]]. Avoid using ftp.archlinux.org as it is [http://www.archlinux.org/news/302/ throttled].
+
  
<pre>
+
Digite uma seleção (padrão=todos): 1-10 15
[repository-name]
+
Server = ftp://server.net/repo
+
</pre>
+
  
<pre>
+
irá selecionar pacotes 1 até 10 e 15 para a instalação, ou:
[core]
+
 
# Add your preferred servers here, they will be used first
+
Digite uma seleção (padrão=todos):: ^5-8 ^2
Include = /etc/pacman.d/core
+
 
</pre>
+
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 programa 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''.
 +
{{Atenção |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 {{ic|Tab}} quando o gerenciador de boot aparecer (para Syslinux) ou {{ic|e}} (para GRUB), renomear {{ic|initramfs-linux-fallback.img}} e pressione {{ic|Enter}} ou {{ic|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]].}}
  
'''n.b.''' Care should be taken when using '''testing''' and '''unstable''' repositories
+
{{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}}.
 +
}}
  
If you receive the following error
+
== Veja também ==
'''not found in sync db'''
+
this likely due to the package not being located because the repositry has not been set correctly.
+
  
==Links Relacionados==
+
* [[Common Applications/Utilities#Package management]]
[[Improve Pacman Performance]]<br>
+
[[Colored Pacman output]]<br>
+
[[Downgrade packages]]<br>
+
[[Redownloading all installed packages]]<br>
+
[[Server_configuration|Server configuration in pacman.conf]]<br>
+
[[ArchLinux User-community Repository (AUR)]]<br>
+
[[Local repository HOW-TO]]<br>
+
[[Custom local repository with ABS and gensync]]<br>
+
[[Howto Upgrade via Home Network]] (Network Shared Pacman Cache)<br>
+
[[rucksack]]<br>
+
[[Pacman GUI Frontends]]<br>
+
[[Pacman_Aliases|Pacman Aliases (for bash)]]
+

Revision as of 10:33, 1 September 2013

Template:Article summary start Template:Article summary text Template:Article summary heading Template:Article summary text Template:Article summary heading Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary heading Template:Article summary link Template:Article summary link Template:Article summary link Template:Article summary link Template:Article summary end

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: execute 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