pacman (Русский)/Tips and tricks (Русский)

From ArchWiki
The printable version is no longer supported and may have rendering errors. Please update your browser bookmarks and please use the default browser print function instead.

Состояние перевода: На этой странице представлен перевод статьи pacman/Tips and tricks. Дата последней синхронизации: 12 июля 2021. Вы можете помочь синхронизировать перевод, если в английской версии произошли изменения.

Полезные советы, которые расширят возможности используемых утилит и самого pacman, можно найти в статьях Базовые утилиты и Bash.

Обслуживание

Примечание: В примерах ниже используется утилита comm, входные данные для которой должны быть предварительно отсортированы утилитой sort. Вместо этого можно использовать команды grep -Fxf и grep -Fxvf.

Смотрите также Обслуживание системы.

Список пакетов

С версией

При составлении отчётов об ошибках или обсуждении установленных пакетов может понадобиться составить список пакетов с версиями.

  • Пакеты, установленные явно: pacman -Qe.
  • Пакеты в группе группа: pacman -Sg группа.
  • Сторонние пакеты (как правило, скачаны и установлены вручную либо были удалены из репозиториев): pacman -Qm.
  • Пакеты из базы синхронизации: pacman -Qn.
  • Пакеты из базы синхронизации, установленные явно и не являющиеся зависимостями, в том числе опциональными: pacman -Qent.
  • Пакеты по регулярному выражению (regex): pacman -Qs regex.
  • Пакеты по регулярному выражению с пользовательским форматом вывода (требуется пакет expac): expac -s '%-30n %v' regex.

С размером

При необходимости освободить место на жёстком диске полезно будет узнать размер установленных пакетов. Можно определить как размер каждого пакета в отдельности, так и суммарный размер пакета и его зависимостей.

По отдельности

Список установленных пакетов с размером:

$ LC_ALL=C pacman -Qi | awk '/^Name/{name=$3} /^Installed Size/{print $4$5, name}' | sort -h
С зависимостями

Размеры пакетов вместе с зависимостями (два способа):

  • Установите пакет expac и выполните expac -H M '%m\t%n' | sort -h.
  • Установите пакет pacgraph и выполните pacgraph -c.

Размер загружаемых пакетов (если пакеты не указать, то будет выведен список всех пакетов в базе синхронизации):

$ expac -S -H M '%k\t%n' пакеты

Размер и описание явно установленных пакетов, не входящих ни в мета-пакет base, ни в группу пакетов base-devel:

$ expac -H M "%011m\t%-20n\t%10d" $(comm -23 <(pacman -Qqen | sort) <(pacman -Qqg base base-devel | sort)) | sort -n

Список пакетов, которым требуется обновление, с размером загрузки:

$ pacman -Quq|xargs expac -S -H M '%k\t%n' | sort -sh

С датой

Список последних 20 установленных пакетов при помощи expac:

$ expac --timefmt='%Y-%m-%d %T' '%l\t%n' | sort | tail -n 20

или в секундах с начала эпохи (1970-01-01 UTC):

$ expac --timefmt=%s '%l\t%n' | sort -n | tail -n 20

Не в группе или репозитории

Примечание: В разделе #Удаление неиспользуемых пакетов описано, как вывести список пакетов, которые были установлены как зависимости, но больше не нужны ни одному пакету.

Список явно установленных пакетов не из мета-пакета base:

$ comm -23 <(pacman -Qqe | sort) <(expac -l '\n' '%E' base | sort)

Список установленных пакетов, которые не входят в мета-пакет base или группу пакетов base-devel:

$ comm -23 <(pacman -Qqe | sort) <({ pacman -Qqg base-devel; expac -l '\n' '%E' base; } | sort -u )

Список установленных пакетов, которые не явлются зависимостями других пакетов и не принадлежат мета-пакету base или группе пакетов base-devel:

$ comm -23 <(pacman -Qqt | sort) <({pacman -Qqg base-devel; expac -l '\n' '%E' base; } | sort -u)

То же, но с описаниями:

$ expac -H M '%-20n\t%10d' $(comm -23 <(pacman -Qqt | sort) <({pacman -Qqg base-devel; expac -l '\n' '%E' base; } | sort -u))

Список пакетов, установленных не из репозитория имя_репозитория:

$ comm -23 <(pacman -Qq | sort) <(pacman -Sql имя_репозитория | sort)

Список пакетов, установленных из репозитория имя_репозитория :

$ comm -12 <(pacman -Qq | sort) <(pacman -Sql имя_репозитория | sort)

Список пакетов Arch Linux ISO, которые не входят в мета-пакет base:

$ comm -23 <(curl https://gitlab.archlinux.org/archlinux/archiso/-/raw/master/configs/releng/packages.x86_64) <(expac -l '\n' '%E' base | sort)

В разработке

Список установленных пакетов, которые считаются нестабильными и/или находятся в стадии активной разработки:

$ pacman -Qq | grep -Ee '-(bzr|cvs|darcs|git|hg|svn)$'

Просмотр пакетов

Следующая команда выведет информацию об установленных пакетах:

$ pacman -Qq | fzf --preview 'pacman -Qil {}' --layout=reverse --bind 'enter:execute(pacman -Qil {} | less)'

Утилита fzf выдаёт данные в терминал в виде двух панелей: названия пакетов слева, информация о них — справа.

Начните вводить буквы, чтобы искать пакет по названию; навигация по списку — стрелками или комбинациями клавиш Ctrl-j/Ctrl-k; нажатие Enter выводит информацию о пакете в формате less.

Следующая команда fzf позволяет просматривать пакеты, о которых знает pacman (и установленные, и не установленные):

$ pacman -Slq | fzf --preview 'pacman -Si {}' --layout=reverse

Клавиши для навигации те же, но Enter не работает.

Список файлов пакета с размером

Если какой-то пакет стал занимать слишком много места на диске и вы хотите понять, какие файлы в этом виноваты, выполните:

$ pacman -Qql пакет | grep -v '/$' | xargs -r du -h | sort -h

Поиск файлов без пакета-владельца

Если в вашей системе появились файлы, которые не принадлежат ни одному пакету (обычная ситуация, если вы не используете пакетный менеджер для установки программ), то стоит их найти и удалить.

Первый способ найти такие файлы — командой pacreport --unowned-files (пакет pacutils) с правами root, которая, помимо прочего, выведет список "ничьих" файлов.

Второй — составить список интересующих файлов и проверить их через pacman:

# find /etc /usr /opt /var | LC_ALL=C pacman -Qqo - 2>&1 >&- > /dev/null | cut -d ' ' -f 5-
Совет: Скрипт lostfiles делает то же самое, но в нём также используется обширный чёрный список для удаления из вывода наиболее часто встречающихся "ложных срабатываний".

Отслеживание созданных пакетами файлов-сирот

Как правило, в нормально функционирующей системе со временем скапливаются файлы-призраки, вроде файлов состояний, логов, индексов и т.п.

Утилита pacreport из пакета pacutils отслеживает такие файлы в привязке к создавшим их пакетам с помощью настроек в файле /etc/pacreport.conf (см. pacreport(1) § FILES).

Пример настроек (сокращённо):

/etc/pacreport.conf
[Options]
IgnoreUnowned = usr/share/applications/mimeinfo.cache

[PkgIgnoreUnowned]
alsa-utils = var/lib/alsa/asound.state
bluez = var/lib/bluetooth
ca-certificates = etc/ca-certificates/trust-source/*
dbus = var/lib/dbus/machine-id
glibc = etc/ld.so.cache
grub = boot/grub/*
linux = boot/initramfs-linux.img
pacman = var/lib/pacman/local
update-mime-database = usr/share/mime/magic

После этого команда pacreport --unowned-files с правами root выведет список файлов-сирот, если связанные с ними пакеты были удалены (или вместо старых файлов были созданы новые).

Кроме того, утилита aconfmgr (aconfmgr-gitAUR) может отслеживать изменённые файлы и файлы без пакета-владельца с помощью скрипта настройки.

Удаление неиспользуемых пакетов

Команда для рекурсивного удаления пакетов-сирот и их файлов настроек:

# pacman -Qqdt | pacman -Rns -

Если неиспользуемых пакетов найдено не было, pacman выведет сообщение error: argument '-' specified with empty stdin. Это нормальное поведение команды pacman -Rns, которой не было передано аргументов.

Примечание: Параметр -Qt выводит только чистые пакеты-сироты. Чтобы включить список пакеты, которые являются опциональными зависимостями, укажите флаг -t дважды (например, -Qtt).

Удаление всех пакетов, кроме базовых

Если возникла необходимость очистить систему, оставив только базовый набор пакетов, то проще всего изменить причину установки ненужных пакетов на "зависимость", после чего удалить неиспользуемые зависимости.

Сначала измените причину установки всех явно установленных пакетов на "зависимость":

# pacman -D --asdeps $(pacman -Qqe)

Затем измените причину установки пакетов, которые вы удалять не хотите, на "установлен явно":

# pacman -D --asexplicit base linux linux-firmware
Примечание:
  • В последней команде следует указать все пакеты, которые должны остаться в системе. В статье Руководство по установке#Установка основных пакетов перечислены пакеты, которые нужны для нормального функционирования базовой системы.
  • Последняя команда удалит также и пакет программы-загрузчика. Система всё ещё будет загружаться, но изменить параметры загрузки станет невозможно.

Наконец, удалите ненужные пакеты-зависимости, как описано в разделе #Удаление неиспользуемых пакетов.

Список зависимостей нескольких пакетов

Ниже приведена команда для вывода списка зависимостей нескольких пакетов, отсортированого в алфавитном порядке с удалением дубликатов.

Примечание: Чтобы вывести информацию только для пакетов, установленных в системе, в команде ниже используйте pacman -Qi.
$ LC_ALL=C pacman -Si пакеты | awk -F'[:<=>]' '/^Depends/ {print $2}' | xargs -n1 | sort -u

То же самое, с помощью expac:

$ expac -l '\n' %E -S пакеты | sort -u

Список изменённых файлов для резервного копирования

Если вы собираетесь сделать резервную копию файлов системных настроек, то самым простым решением будет скопировать целиком каталог /etc/. Однако правильнее будет выполнить копирование только для тех файлов, которые были изменены. Модифицированные резервные копии файлов можно найти следующей командой:

# pacman -Qii | awk '/^MODIFIED/ {print $2}'

Команда должна выполняться с правами root, чтобы в список вошли файлы, владельцем которых является суперпользователь (вроде файла /etc/sudoers).

Совет: В разделе #Список изменённых файлов пакетов описано, как вывести список всех известных pacman изменённых файлов, а не только файлы с резервными копиями.

Резервная копия базы данных pacman

Следующая команда создаст резервную копию локальной базы данных pacman:

$ tar -cjf pacman_database.tar.bz2 /var/lib/pacman/local

Сохраните резервную копию на одном или нескольких внешних устройствах, вроде USB-накопителя, внешнего жесткого диска или CD-R.

Чтобы восстановить базу данных, поместите файл pacman_database.tar.bz2 в каталог / и выполните:

# tar -xjvf pacman_database.tar.bz2
Примечание: Если файлы базы данных pacman повреждены, а резервные копии отсутствуют, надежда на восстановление базы данных всё же остаётся. Подробнее см. #Восстановление локальной базы данных.
Совет: Пакет pakbak-gitAUR содержит скрипт и службу systemd для автоматизации этой задачи. Настройка осуществляется с помощью файла /etc/pakbak.conf.

Просмотр списка изменений пакета

При внесении изменений в состав пакета сопроводители часто подробно комментируют произведённые правки. Утилита pacologAUR позволяет просматривать эти комментарии из командной строки. Команда pacolog пакет выведет последние сообщения о правках для пакетов из официальных репозиториев и AUR.

Установка и восстановление

Альтернативные способы получения и восстановления пакетов.

Установка пакетов с CD/DVD или USB-накопителя

Загрузите пакеты или группы пакетов:

# cd ~/Packages
# pacman -Syw  --cachedir . base base-devel grub-bios xorg gimp
# repo-add ./custom.db.tar.gz ./*

По умолчанию pacman работает с деревом каталогов (и базами данных) на хосте, поэтому он не сможет правильно разрешать и загружать зависимости. Если необходимы все пакеты и зависимости, лучше создать временную пустую базу данных и работать с ней через опцию --dbpath:

# mkdir /tmp/blankdb
# pacman -Syw --cachedir . --dbpath /tmp/blankdb base base-devel grub-bios xorg gimp	 	
# repo-add ./custom.db.tar.gz ./*

Затем запишите каталог Packages на CD/DVD, USB-накопитель, внешний жёсткий диск и т.д.

Установка пакетов:

1. Примонтируйте носитель:

# mkdir /mnt/repo
# mount /dev/sr0 /mnt/repo    # Для CD/DVD.
# mount /dev/sdxY /mnt/repo   # Для USB.

2. Отредактируйте файл pacman.conf, добавив свой репозиторий перед всеми остальными (extra, core и др.). Это необходимо, чтобы пакеты на CD/DVD/USB получили приоритет над пакетами в стандартных репозиториях:

/etc/pacman.conf
[custom]
SigLevel = PackageRequired
Server = file:///mnt/repo/Packages

3. В заключение, синхронизируйте базу данных pacman, чтобы получить доступ к новому репозиторию:

# pacman -Syu

Собственный локальный репозиторий

Скрипт repo-add (входит в состав pacman) может создать базу данных для личного репозитория. Команда repo-add --help выведет краткую информацию о работе утилиты. База данных пакетов представляет собой tar-файл, возможно сжатый, с суффиксом .db или .files, за которым следует суффикс архива .tar, .tar.gz, .tar.bz2, .tar.xz, .tar.zst или .tar.Z. На момент запуска утилиты базы может ещё не быть, но родительские каталоги уже должны быть созданы.

Следующая команда добавляет новый пакет к базе данных или заменяет старую версию существующего пакета на более новую:

$ repo-add /путь/к/репозиторию.db.tar.gz /путь/к/пакету-1.0-1-x86_64.pkg.tar.xz

Для работы repo-add база данных и пакеты могут храниться в разных каталогах, но когда вы станете работать с базой через pacman, её нужно объединить с пакетами в одном месте. Хранение всех пакетов репозитория в одном каталоге также позволяет использовать подстановочные символы в командной оболочке, чтобы добавлять или обновлять несколько пакетов за раз:

$ repo-add /путь/к/репозиторию.db.tar.gz /путь/к/*.pkg.tar.xz
Важно: repo-add добавляет элементы в базу данных в том порядке, в каком получает их из командной строки. Если добавляется несколько разных версий одного и того же пакета, убедитесь, что правильная версия указана последней. В частности, обратите внимание, что лексический порядок командной оболочки зависит от локали и может отличаться от правил сравнения версий пакетов pacman (см. vercmp(8)).

Если вы собираетесь поддерживать несколько версий пакета для разных архитектур, то следует соблюдать некоторые предосторожности. Под каждую архитектуру должен быть выделен отдельный каталог:

$ tree ~/customrepo/ | sed "s/$(uname -m)/архитектура/g"
/home/archie/customrepo/
└── архитектура
    ├── customrepo.db -> customrepo.db.tar.xz
    ├── customrepo.db.tar.xz
    ├── customrepo.files -> customrepo.files.tar.xz
    ├── customrepo.files.tar.xz
    └── personal-website-git-b99cce0-1-архитектура.pkg.tar.xz

1 directory, 5 files

При запуске repo-add проверяет, подходят ли пакеты для добавления в базу. Если нет, то появится сообщение об ошибке:

==> ERROR: '/home/archie/customrepo/архитектура/foo-архитектура.pkg.tar.xz' does not have a valid database archive extension.

Утилита repo-remove удаляет пакеты из базы данных:

$ repo-remove /путь/к/repo.db.tar.gz пакеты

После создания локальной базы данных укажите репозиторий в файле pacman.conf на каждой системе, где он будет использоваться. Пример настроек пользовательского репозитория можно найти в самом файле. Название репозитория представляет собой имя файла базы данных без суффикса. В примере выше репозиторий называется repo. Ссылаться на репозиторий можно по URL file:// или через FTP ftp://localhost/path/to/directory.

При желании добавьте свой репозиторий в список неофициальных репозиториев, чтобы сообщество могло извлечь из него пользу.

Сетевой кэш pacman с совместным доступом

Если в вашей локальной сети есть несколько машин с Arch Linux, сетевой кэш позволит значительно уменьшить время загрузки новых пакетов. При этом важно помнить, что в кэше не должно быть пакетов для разных архитектур (например, i686 и x86_64), иначе возникнут проблемы.

Кэш только на чтение

В качестве быстрого решения подойдёт веб-сервер darkhttpd. Остальные машины будут использовать его в качестве зеркала для скачивания пакетов:

# ln -s /var/lib/pacman/sync/*.db /var/cache/pacman/pkg
$ sudo -u http darkhttpd /var/cache/pacman/pkg --no-server-id

darkhttpd можно также запустить как службу systemd. Добавьте свой сервер в список зеркал /etc/pacman.d/mirrorlist на клиентских машинах строкой Server = http://зеркало:8080. Убедитесь, что зеркало обновляется.

Если вы уже запустили веб-сервер для каких-то других целей, его можно использовать как сервер локального репозитория вместо darkhttpd. Например, для сервера nginx добавьте в настройки блок правил server с указанием прослушивать порт 8080:

/etc/nginx/nginx.conf
server {
    listen 8080;
    root /var/cache/pacman/pkg;
    server_name myarchrepo.localdomain;
    try_files $uri $uri/;
}

Не забудьте после этого перезапустить nginx.

Какой бы веб-сервер вы ни использовали, нужно открыть порт 8080 для трафика из локальной сети (и, при необходимости, включить блокировку пакетов, приходящих извне). Например, для iptables добавьте правило -s 192.168.0.0/16 -p tcp --dport 8080 -j ACCEPT, необходимым образом скорректировав параметры локальной подсети.

Overlay-монтирование кэша только на чтение

Можно настроить использование отдельной машины в локальной сети как read-only кэш пакетов. Для этого используется overlay-монтирование каталога /var/cache/pacman/pkg. Преимущество такой конфигурации — на сервере установлен полный набор новейших пакетов, которые используются другими машинами; в результате можно сэкономить внешнюю (из локальной сети) пропускную способность.

Пример:

# mkdir /tmp/remote_pkg /mnt/workdir_pkg /tmp/pacman_pkg
# sshfs <remote_username>@<remote_pkgcache_addr>:/var/cache/pacman/pkg /tmp/remote_pkg -C
# mount -t overlay overlay -o lowerdir=/tmp/remote_pkg,upperdir=/var/cache/pacman/pkg,workdir=/mnt/workdir_pkg /tmp/pacman_pkg

Замечание по поводу overlay: рабочий каталог должен быть пустым каталогом на том же смонтированном устройстве, что и upperdir.

После этого запустите pacman с опцией --cachedir /tmp/pacman_pkg:

# pacman -Syu --cachedir /tmp/pacman_pkg

Распределённый кэш только на чтение

В Arch Linux есть несколько инструментов, которые выполняют автоматический поиск кэша пакетов на других компьютерах в локальной сети. Среди них pacredir, pacserve, pkgdistcacheAUR и paclanAUR. pkgdistcache использует Avahi вместо чистого UDP, который может работать лучше в некоторых домашних сетях, где используется связка WiFi и Ethernet.

Также раньше использовались утилиты PkgD и multipkg, но их разработка была прекращена.

Кэш на чтение и запись

Чтобы несколько машин могли работать с общим кэшем пакетов, откройте совместный доступ к каталогу /var/cache/pacman/ с помощью любого сетевого протокола монтирования файловых систем. В этом разделе описано, как использовать shfs и SSHFS для организации совместного доступа к кэшу пакетов и некоторым каталогам с библиотеками в локальной сети. Имейте в виду, что сетевой кэш может быть довольно медленным, в том числе и из-за выбранной файловой системы.

Во-первых, установите любой пакет с поддержкой сетевых файловых систем: shfs-utils, sshfs, curlftpfs, samba или nfs-utils.

Совет:
  • Полезную информацию о работе с sshfs и shfs можно найти в статье Ключи SSH.
  • smbfs по умолчанию не умеет работать с файлами, имена которых содержат двоеточия. В итоге клиент будет загружать такие пакеты заново при каждом обновлении. Чтобы это предотвратить, используйте на системе-клиенте опцию монтирования mapchars.

Теперь, чтобы открыть совместный доступ к пакетам, смонтируйте каталог сервера /var/cache/pacman/pkg в каталог /var/cache/pacman/pkg на клиентских машинах.

Важно: Не следует делать каталог /var/cache/pacman/pkg или один из его родительских каталогов (например, /var/) символической ссылкой. Pacman ожидает, что это будут именно каталоги. Когда pacman будет переустанавливать или обновлять самого себя, он удалит все символические ссылки и создаст вместо них пустые каталоги. Одноко поскольку при этом pacman полагается на некоторые файлы в этих каталогах, то процесс обновления будет нарушен. Подробнее см. FS#50298.

Двухсторонний кэш на основе rsync

Другой подход к созданию сетевого кэша — использовать rsync. Настройте сервер кэша, запустите на нём демон rsync и выполните двухсторонную синхронизацию между сервером и клиентскими машинами по протоколу rsync. В этом случае имена файлов с двоеточиями проблемы не создадут.

Ниже приведён пример работы с кэшем на машине-клиенте. Команда uname -m позволяет выполнить синхронизацию пакетов с учётом архитектуры:

 # rsync rsync://server/share_$(uname -m)/ /var/cache/pacman/pkg/ ...
 # pacman ...
 # paccache ...
 # rsync /var/cache/pacman/pkg/ rsync://server/share_$(uname -m)/  ...

Динамический обратный прокси-кэш на основе nginx

Сервер nginx может работать в качестве посредника для запросов пакетов на официальные upstream-зеркала, кэшируя ответы на локальном диске. Все последующие запросы к этим пакетам будут адресоваться к локальному кэшу, минимизируя интернет-трафик при обновлении большого количества компьютеров.

В примере ниже кэширующий сервер запущен на адресе http://cache.domain.example:8080/. Пакеты хранятся в каталоге /srv/http/pacman-cache/.

Установите nginx на машине, предназначенной для хранения кэша. Создайте каталог кэша с необходимыми разрешениями, чтобы nginx мог записывать в него файлы:

# mkdir /srv/http/pacman-cache
# chown http:http /srv/http/pacman-cache

Используйте этот файл настроек в качестве отправной точки для редактирования /etc/nginx/nginx.conf. Проверьте, чтобы директива resolver работала так, как ожидается. В блоках правил исходящех запросов server укажите директиву proxy_pass с адресами официальных зеркал (пример ожидаемого формата этой директивы можно найти в самом файле настроек). После настройки включите и запустите nginx.

Чтобы использовать кэш на каждом компьютере с Arch Linux (включая тот, который хранит кэш), нужно добавить следующую строку в начало файла mirrorlist:

/etc/pacman.d/mirrorlist
Server = http://cache.domain.example:8080/$repo/os/$arch
...
Примечание: Поскольку каталог кэша будет расти с течением времени, необходимо предусмотреть метод удаления старых пакетов. Утилита paccache (входит в пакет pacman-contrib) автоматизирует очистку в соответствии с различными критериями. Например, команда find /srv/http/pacman-cache/ -type d -exec paccache -v -r -k 2 -c {} \; оставит в кэше только две последние версии каждого пакета.

Кэширующий прокси-сервер Pacoloco

Pacoloco — простой прокси-сервер для кэша пакетов из репозиториев pacman. Устанавливается с пакетом pacoloco. Откройте файл настроек и добавьте зеркала pacman:

/etc/pacoloco.yaml
port: 9129
repos:
  mycopy:
    urls:
      - http://mirror.lty.me/archlinux
      - http://mirrors.kernel.org/archlinux

Перезапустите pacoloco.service и после этого прокси-репозиторий будет доступен по адресу http://сервер:9129/repo/mycopy.

Кэширующий прокси-сервер Flexo

Flexo — ещё один кэширующий прокси для репозиториев pacman. Flexo доступен в AUR: flexo-gitAUR. После установки запустите службу flexo.service.

Flexo по умолчанию работает на порте 7878. Добавьте строку Server = http://мой_сервер:7878/$repo/os/$arch в самое начало файла /etc/pacman.d/mirrorlist, чтобы pacman загружал пакеты через Flexo.

Синхронизация кэша пакетов специальными программами

Утилиты Syncthing и Resilio Sync можно использовать для синхронизации каталогов кэша pacman (например, /var/cache/pacman/pkg).

Предотвращение нежелательной очистки кэша пакетов

По умолчанию команда pacman -Sc очищает кэш от старых версий пакетов, которые были удалены из системы. В условиях совместного доступа к кэшу от нескольких машин в локальной сети pacman не может достоверно определить, какие пакеты установлены на каждой системе. По этой причине очистку кэша нужно ограничить.

Добавьте следующий пункт в раздел [options] файла /etc/pacman.conf, чтобы удалялись только устаревшие версии пакетов:

CleanMethod = KeepCurrent

Воссоздание пакета из файловой системы

С помощью пакета fakepkgAUR можно воссоздать пакет из файловой системы. Файлы будут собраться в том виде, в каком они есть, следовательно, сделанные в них изменения войдут в "собранный" пакет. Поэтой причине распространять пакет среди других пользователей не рекомендуется; для этого гораздо лучше подойдёт система сборки Arch или архив Arch Linux.

Список установленных пакетов

Создание списка явно установленных пакетов может оказаться полезным, если вы собираетесь сделать резервную копию системы или ускорить процесс установки на новой машине:

$ pacman -Qqe > pkglist.txt
Примечание:
  • С параметром -t в список не будут включены пакеты, которые нужны другим явно установленным пакетам. При переустановке по этому списку они всё равно будут установлены, но уже как зависимости.
  • С опцией -n в список не войдут внешние пакеты (например, из АУР).
  • Команда comm -13 <(pacman -Qqdt | sort) <(pacman -Qqdtt | sort) > optdeplist.txt создаст список установленных опциональных зависимостей, которые можно будет переустановить с параметром --asdeps.
  • Команда pacman -Qqem > foreignpkglist.txt создаст список пакетов из AUR и других внешних пакетов, которые были установлены явно.

Хук pacman позволит автоматизировать обновление списка пакетов. Пример:

[Trigger]
Operation = Install
Operation = Remove
Type = Package
Target = *

[Action]
When = PostTransaction
Exec = /bin/sh -c '/usr/bin/pacman -Qqe > /etc/pkglist.txt'

Установка пакетов по списку

Следующая команда установит пакеты в соответствии с ранее созданным списком, при этом уже установленные пакеты переустанавливаться не будут:

# pacman -S --needed - < pkglist.txt

В списке могут оказаться внешние пакеты, из AUR или установленные локально. Чтобы их исключить, вместо предыдущей команды выполните следующую:

# pacman -S --needed $(comm -12 <(pacman -Slq | sort) <(sort pkglist.txt))

Наконец, убедитесь, что установленные в системе пакеты совпадают со списком, и удалите всё, что в него не входит:

# pacman -Rsu $(comm -23 <(pacman -Qq | sort) <(sort pkglist.txt))
Совет: Данные действия можно автоматизировать. См. bacpacAUR, packupAUR, pacmanityAUR и pugAUR.

Список изменённых файлов пакетов

Если вы предполагаете, что какие-то файлы были повреждены (например, из-за ошибки программы или аппаратного обеспечения), стоит проверить их хэш-суммы. Сделать это можно с помощью пакета pacutils:

# paccheck --md5sum --quiet

Восстановление базы данных описано в разделе #Восстановление локальной базы данных. Файлы mtree можно также извлечь как .MTREE из соответствующих файлов пакета.

Примечание: Этот способ не подходит, если есть подозрение на злонамеренные изменения. В этом случае используйте live-окружение и независимый источник хэш-сумм.

Переустановка всех пакетов

Чтобы переустановить все пакеты, установленные из базы синхронизации, выполните:

# pacman -Qqn | pacman -S -

Сторонние пакеты (AUR) придётся установить отдельно; найти их можно командой pacman -Qqm.

По умолчанию при переустановке пакета pacman оставляет причину установки без изменений.

Важно: Принудительно перезаписать все пакеты можно флагом --overwrite=*. Учтите — это средство на самый крайний случай, см. Обслуживание системы#Избегайте определенных команд pacman.

Восстановление локальной базы данных

См. pacman/Восстановление локальной базы данных.

Восстановление USB-носителя из существующей установки

Если вы установили Arch на USB-носитель и испортили его (например, выдернув носитель в процессе записи), стоит попробовать переустановить все пакеты. Возможно, это восстановит работоспособность флешки. Предположим, USB-носитель смонтирован в каталог /newarch:

# pacman -S $(pacman -Qq --dbpath /newarch/var/lib/pacman) --root /newarch --dbpath /newarch/var/lib/pacman

Просмотр отдельного файла внутри файла .pkg

Например, вы хотите увидеть содержимое файла /etc/systemd/logind.conf в пакете systemd:

$ bsdtar -xOf /var/cache/pacman/pkg/systemd-204-3-x86_64.pkg.tar.xz etc/systemd/logind.conf

Для просмотра файлов архива можно использовать vim:

$ vim /var/cache/pacman/pkg/systemd-204-3-x86_64.pkg.tar.xz

Список приложений, использующих устаревшие библиотеки

Даже после установки новой версии пакета некоторые долгоиграющие программы (например, демоны и серверы) могут всё ещё использовать код из библиотек старого пакета. Если такая библиотека содержит уязвимость или опасный баг, продолжать её использовать — не самая лучшая идея.

Следующая команда найдёт все программы, которые используют устаревший код:

# lsof +c 0 | grep -w DEL | awk '1 { print $1 ": " $NF }' | sort -u

Будут выведены названия работающих программ, а также старые библиотеки, которые были удалены или замещены более новыми.

Установка контента только на нужном языке

Многие пакеты по умолчанию устанавливают документацию и переводы на нескольких языках. Существует ряд программ, разработаных для удаления таких ненужных файлов. Например, утилита localepurgeAUR удалит лишние файлы локалей, если запустить её после установки пакета. Более прямой подход к этой проблеме — указать директиву NoExtract в файле pacman.conf, что предотвратит установку ненужных файлов.

Важно: Некоторые пользователи отмечали, что удаление локалей может привести к неожиданным последствиям, даже в Xorg.

В примере ниже устанавлены будут только английские (US) файлы, или никакие вообще:

/etc/pacman.conf
NoExtract = usr/share/help/* !usr/share/help/C/*
NoExtract = usr/share/gtk-doc/html/*
NoExtract = usr/share/locale/* usr/share/X11/locale/*/* usr/share/i18n/locales/* opt/google/chrome/locales/* !usr/share/X11/locale/C/*
NoExtract = !*locale*/en*/* !usr/share/*locale*/locale.*
NoExtract = !usr/share/*locales/en_?? !usr/share/*locales/i18n* !usr/share/*locales/iso*
NoExtract = usr/share/i18n/charmaps/* !usr/share/i18n/charmaps/UTF-8.gz
NoExtract = !usr/share/*locales/trans*
NoExtract = usr/share/man/* !usr/share/man/man*
NoExtract = usr/share/vim/vim*/lang/*
NoExtract = usr/lib/libreoffice/help/en-US/*
NoExtract = usr/share/kbd/locale/*
NoExtract = usr/share/*/translations/*.qm usr/share/qt/translations/*.pak !*/en-US.pak # Qt apps
NoExtract = usr/share/*/locales/*.pak opt/*/locales/*.pak usr/lib/*/locales/*.pak !*/en-US.pak # Electron apps
NoExtract = opt/onlyoffice/desktopeditors/dictionaries/* !opt/onlyoffice/desktopeditors/dictionaries/en_US/*
NoExtract = opt/onlyoffice/desktopeditors/editors/web-apps/apps/*/main/locale/* !*/en.json
NoExtract = opt/onlyoffice/desktopeditors/editors/web-apps/apps/*/main/resources/help/* !*/help/en/*
NoExtract = opt/onlyoffice/desktopeditors/converter/empty/*/*
NoExtract = usr/share/ibus/dicts/emoji-*.dict !usr/share/ibus/dicts/emoji-en.dict

Производительность

Увеличение скорости загрузки

Примечание: Если у вас возникли проблемы со скоростью загрузки, убедитесь, что вы используете одно из зеркал из списка, а не ftp.archlinux.org [1].

При загрузке пакетов pacman использует зеркала в том порядке, в каком они перечислены в файле /etc/pacman.d/mirrorlist. Зеркало, указанное первым, будет использоваться по умолчанию, и совсем не обязательно оно окажется для вас самым быстрым. Подробнее о выборе зеркал см. Зеркала.

Скорость загрузки пакетов можно повысить, если использовать сторонние приложения для загрузки вместо встроенного в pacman менеджера закачек, или настроив параллельную загрузку.

В любом случае, прежде чем делать какие-либо изменения, убедитесь, что используете последнюю версию pacman:

# pacman -Syu

Powerpill

Powerpill — обёртка для pacman, которая использует параллельную и сегментированную загрузку для повышения скорости.

wget

Эта утилита будет очень полезна, если вам нужны более сложные настройки прокси, чем это позволяют возможности pacman.

Установите пакет wget, после чего отредактируйте /etc/pacman.conf, указав в разделе [options] следующую строку:

XferCommand = /usr/bin/wget --passive-ftp --show-progress -c -q -N %u

Чтобы не указывать параметры wget в файле /etc/pacman.conf, можно отредактировать непосредственно файл настроек wget — либо общесистемный файл /etc/wgetrc, либо пользовательский $HOME/.wgetrc.

aria2

aria2 — небольшая загрузочная утилита с поддержкой возобновляемой и сегментной загрузки по протоколам HTTP/HTTPS и FTP. aria2 создаёт несколько одновременных соединений с зеркалом Arch, что увеличивает скорость загрузки файлов и пакетов.

Примечание: Если указать aria2 в параметре XferCommand, то пакеты всё равно будут загружаться по очереди, а не параллельно. Pacman использует команду XferCommand для одного пакета за раз и ожидает её завершения, прежде чем перейти к следующему. Параллельная загрузка нескольких пакетов возможна с Powerpill.

Установите aria2, затем добавьте следующую строку в раздел [options] файла /etc/pacman.conf:

XferCommand = /usr/bin/aria2c --allow-overwrite=true --continue=true --file-allocation=none --log-level=error --max-tries=2 --max-connection-per-server=2 --max-file-not-found=5 --min-split-size=5M --no-conf --remote-time=true --summary-interval=60 --timeout=5 --dir=/ --out %o %u
Совет: На форуме предложен более простой способ настройки pacman на работу через aria2, с добавлением некоторых полезных опций.

Параметры aria2 описаны в руководстве aria2c(1) § OPTIONS. Некоторые разъяснения о параметрах последней команды:

  • -d, --dir: каталог для сохранения скачиваемых файлов.
  • -o, --out: итоговые имена скачиваемых файлов.
  • %o: локальное имя файла в представлении pacman.
  • %u: URL загрузки в представлении pacman.

Другие приложения

Есть и другие загрузочные приложения, с которыми может работать pacman. Ниже приводится список в виде соответствующих настроек XferCommand:

Утилиты

  • Lostfiles — Скрипт для обнаружения файлов, не принадлежащих ни одному пакету.
https://github.com/graysky2/lostfiles || lostfiles
  • Pacmatic — Обёртка для Pacman; проверяет новости Arch перед обновлением, запрещает частичные обновления, предупреждает об изменении файлов настроек.
http://kmkeen.com/pacmatic || pacmatic
  • pacutils — Библиотека для программ, основанных на libalpm.
https://github.com/andrewgregory/pacutils || pacutils
  • pkgfile — Утилита, которая находит, какому пакету принадлежит файл.
https://github.com/falconindy/pkgfile || pkgfile
  • pkgtools — Коллекция скриптов для пакетов Arch Linux.
https://github.com/Daenyth/pkgtools || pkgtoolsAUR
  • pkgtop — Интерактивный менеджер пакетов и системный менеджер, разработанный для GNU/Linux.
https://github.com/orhun/pkgtop || pkgtop-gitAUR
  • Powerpill — Использует параллельную и сегментную загрузку с помощью aria2 и Reflector, чтобы ускорить скачивание пакетов через pacman.
https://xyne.dev/projects/powerpill/ || powerpillAUR
  • repoctl — Утилита для управления локальными репозиториями.
https://github.com/cassava/repoctl || repoctlAUR
  • repose — Программа для создания репозиторев Arch Linux.
https://github.com/vodik/repose || repose
  • snap-pac — Заставляет pacman использовать snapper для создания снимков до и после транзакции, как в YaST из openSUSE.
https://github.com/wesbarnett/snap-pac || snap-pac
  • vrms-arch — Виртуальный Ричард Столлман подсказывает тебе, какие несвободные пакеты установлены в системе.
https://github.com/orospakr/vrms-arch || vrms-arch-gitAUR

Графические

Важно: PackageKit по умолчанию использует права суперпользователя, поэтому настоятельно не рекомендуется его использовать. См. FS#50459 и FS#57943.
  • Apper — Менеджер пакетов на основе PackageKit; написан на C++ с использованием Qt 5. Поддержка метаданных AppStream.
https://userbase.kde.org/Apper || apper
  • Deepin App Store — Сторонний магазин приложений для DDE, собранный с DTK используя PackageKit. Поддерживает метаданные AppStream.
https://github.com/dekzi/dde-store || deepin-store
https://userbase.kde.org/Discover || discover
  • GNOME PackageKit — Менеджер пакетов на основе PackageKit, написан на Си с использованием GTK 3.
https://freedesktop.org/software/PackageKit/ || gnome-packagekit
https://wiki.gnome.org/Apps/Software || gnome-software
  • pcurses — Обёртка для pacman на C++ с текстовым интерфейсом curses.
https://github.com/schuay/pcurses || pcurses
  • tkPacman — Tk-обёртка для pacman, написанная на Tcl.
https://sourceforge.net/projects/tkpacman || tkpacmanAUR