pacman (Русский)
Ссылки по теме
- Создание пакетов
- Откат пакетов
- pacman/Подпись пакета
- pacman (Русский)/Pacnew и Pacsave
- pacman/Восстановление локальной базы данных
- pacman/Rosetta
- pacman/Советы и приёмы
- ЧаВо#Управление пакетами
- Обслуживание системы Пакетный менеджер pacman — одна из важнейших отличительных особенностей Arch Linux. Он объединил в себе двоичный формат пакетов и лёгкую в использовании систему сборки. Цель pacman — удобное управление пакетами вне зависимости от того, взяты они из официальных репозиториев или же собраны самостоятельно. Pacman поддерживает систему в актуальном состоянии, синхронизируя пакеты с мастер-сервером. Эта клиент-серверная модель позволяет пользователю скачивать/устанавливать пакеты со всеми необходимыми зависимостями всего одной командой. Pacman написан на языке Си и работает с tar-пакетами в формате bsdtar(1).
- все (скомпилированные) файлы приложения;
- метаданные о приложении (имя приложения, версия, зависимости и т.д.);
- установочные файлы и директивы для pacman;
- (необязательно) дополнительные файлы для облегчения жизни, например — сценарии запуска/остановки.
- удобное обновление: pacman будет устанавливать обновления по мере их появления;
- проверка зависимостей: pacman самостоятельно отслеживает зависимости, вам нужно только указать целевую программу, и pacman установит её вместе с неоходимыми дополнительными пакетами;
- чистое удаление: pacman хранит список файлов всех пакетов. При удалении пакета в системе не остаётся лишнего "мусора".
- Можно выполнить откат пакета без необходимости искать где-то (например, в архиве Arch Linux) его старую версию;
- Удалённый по ошибке пакет можно заново установить из кэша, не скачивая из репозитория.
- установлен явно (explicitly-installed): установлен пользователем командами или ;
- зависимость (dependency): установлен автоматически в процессе установки другого пакета, поскольку являлся его зависимостью.
- Если база данных не заблокирована, то транзакция инициализируется.
- Определяются пакеты, над которыми будут выполняться действия.
- В зависимости от заданных флагов выполняется подготовка транзакции, проверяется целостность базы данных, а также пакеты и их зависимости.
- Транзакция выполняется:
- Загружаются пакеты (), если это необходимо.
- Выполняются -хуки, которые возможно применить.
- Удаляются пакеты, которые должны быть заменены, конфликтуют или явно указаны для удаления.
- Добавляются пакеты.
- Если пакет содержит установочный сценарий, выполняется функция
pre_install
(/ для обновляемых и удаляемых пакетов соответственно). - Удаляются существующие файлы пакета (при обновлении или удалении пакета). Сохраняются только файлы настроек (смотрите /Pacnew and Pacsave).
- Распаковывается архив с новыми файлами пакета; файлы размещаются в нужные места файловой системы (при установке или обновлении пакета). Изменённые пользователем файлы настроек, которые нельзя просто перезаписать, остаются без изменений; новые файлы настроек сохраняются с суффиксом .pacnew (смотрите предыдущий шаг).
- Если пакет содержит установочный сценарий, выполняется функция (
post_upgrade
/ для обновляемых и удаляемых пакетов соответственно).
- Если пакет содержит установочный сценарий, выполняется функция
- Выполняются -хуки, которые возможно применить.
- Завершение транзакции и освобождение ресурсов (например, разблокирование базы данных).
- В опцию пропишите путь к новому каталогу. Не забудьте добавить косую черту в конце. Это рекомендуемое решение.
- Примонтируйте отдельный раздел в
- Сделайте bind mount в
- Загрузитесь, используя Arch Live USB. Желательно, чтобы версия pacman в образе была не старше той, что установлена в системе.
- Смонтируйте корневую файловую систему, например, командой от root, и убедитесь, что в точке монтирования достаточно свободного места (команда
df -h
). - Смонтируйте файловые системы proc, sys и dev:
- Если в системе используются стандартное расположение баз данных и каталогов, то можно синхронизировать базу данных pacman и обновить систему командой с правами root.
- Кроме того, если не удаётся обновить систему, изучите рекомендации из pacman/Советы и приёмы#Переустановка всех пакетов.
- После обновления стоит убедиться, что в системе не осталось необновлённых нерабочих пакетов: .
- Если такие пакеты всё же есть, их нужно переустановить: .
- Узнайте зависимости пакета .
- Скачайте пакеты с любого рабочего зеркала.
- Извлеките каждый пакет в корневой каталог.
- Переустановите эти пакеты командами , чтобы обновить базу данных.
- Выполните полное обновление системы.
pacman -Ql pacman pacman-contrib | grep -E 'bin/.+'
выведет полный список доступных утилит.Использование
В этом разделе приведена небольшая подборка доступных возможностей pacman. Больше примеров можно найти в руководстве .
Установка пакетов
Пакет представляет собой архив, в котором содержатся:
Pacman, менеджер пакетов Arch Linux, может устанавливать, обновлять и удалять пакеты. Использование пакетов имеет ряд преимуществ по сравнению с альтернативным подходом — ручной компиляцией и установкой программ:
Установка отдельных пакетов
Для установки одного пакета или списка пакетов (включая зависимости) используйте следующую команду:
# pacman -S название_пакета1 название_пакета2 ...Для установки списка пакетов при помощи поиска по регулярному выражению (смотрите эту ветку форума) выполните:
# pacman -S $(pacman -Ssq регулярное_выражение)Если пакет имеет несколько версий в разных репозиториях (например, в extra и testing), можно указать, откуда именно следует установить пакет:
# pacman -S extra/имя_пакетаЧтобы установить несколько пакетов с частично совпадающими названиями, используйте фигурные скобки:
# pacman -S plasma-{desktop,mediacenter,nm}Можно использовать несколько уровней вложенных фигурных скобок:
# pacman -S plasma-{workspace{,-wallpapers},pa}Виртуальные пакеты
Виртуальным называется такой пакет, который сам по себе не существует, но предоставляется другими пакетами. "Виртуальность" позволяет другим пакетам не объявлять зависимостью какой-то конкретный пакет, если есть возможность выбора из нескольких кандидатов. Виртуальный пакет нельзя установить по имени, он добавляется в систему только при установке пакета, который предоставляет его.
Установка группы пакетов
Некоторые пакеты объединены в группы и могут устанавливаться одной командой. Например, после команды
# pacman -S gnomeвам будет предложено выбрать пакеты из группы , которые вы хотели бы установить.
Некоторые группы содержат большое количество пакетов, и среди них могут быть всего несколько нужных или ненужных вам. Вместо того, чтобы вводить все необходимые вам номера, иногда удобнее выбрать или исключить отдельные числа или диапазоны чисел при помощи приведенного ниже синтаксиса:
Enter a selection (default=all): 1-10 15— будут выбраны все пакеты в диапазоне с 1 по 10, а также 15;
Enter a selection (default=all): ^5-8 ^2— будут выбраны все пакеты, кроме входящих в диапазон с 5 по 8, а также 2.
Чтобы увидеть список пакетов, принадлежащих к группе gnome, выполните:
# pacman -Sg gnomeПеречень групп можно найти на странице https://archlinux.org/groups/.
Удаление пакетов
Удалить пакет, не удаляя его зависимости:
# pacman -R название_пакетаУдалить пакет и те его зависимости, которые не нужны никаким другим пакетам:
# pacman -Rs название_пакетаКоманда выше может не сработать при удалении группы с другими необходимыми пакетами. В этом случае используйте команду:
# pacman -Rsu название_пакетаУдалить пакет, его зависимости, а также все пакеты, для которых он сам является зависимостью:
# pacman -Rsc название_пакетаУдалить пакет, который требуется другому пакету, без удаления зависимостей:
Pacman создает резервные копии конфигурационных файлов удаляемых приложений и добавляет к ним расширение .pacsave. Если вы хотите удалить и эти файлы, используйте ключ :
# pacman -Rn название_пакетаОбновление пакетов
Pacman полностью обновляет систему всего одной командой. Если система давно не обновлялась, процесс может занять довольно длительное время. Приведённая ниже команда одновременно синхронизирует базы данных репозиториев и выполняет обновление системы — при этом пакеты, которых нет в подключённых репозиториях, обновлены не будут:
# pacman -SyuЗапросы к базам данных пакетов
Для взаимодействия с базами данных в pacman предусмотрены флаги (база данных пакетов), -S
(база данных синхронизации) и (база данных файлов). Команды , и выведут список возможных опций для этих флагов.
Pacman может выполнять поиск в базе данных как среди названий пакетов, так и по их описаниям:
$ pacman -Ss условие1 условие2 ...Иногда поиск с параметром -s
выдаёт много ненужных результатов, поэтому имеет смысл ограничить поиск только названиями пакетов, отключив поиск по описаниям и другим полям. Для этого можно использовать регулярные выражения:
Искать среди установленных пакетов:
$ pacman -Qs условие1 условие2 ...Искать пакет в репозиториях по названию файла:
$ pacman -F условие1 условие2 ...Показать подробную информацию о пакете в репозитории:
$ pacman -Si название_пакетаТо же самое — для установленного пакета:
$ pacman -Qi название_пакетаЕсли указать сразу два флага , то будет также выведен список резервных копий файлов и их состояние (модифицирован/нет):
$ pacman -Qii название_пакетаВывести список файлов установленного пакета:
$ pacman -Ql название_пакетаВывести список файлов пакета в репозитории:
$ pacman -Fl название_пакетаПроверить наличие файлов установленного пакета:
$ pacman -Qk название_пакетаС двумя флагами проверка будет более тщательной.
Узнать, какому пакету принадлежит файл:
$ pacman -Qo /путь/к/файлу/имя_файлаУзнать, какому пакету в репозиториях принадлежит файл:
$ pacman -F /путь/к/файлу/имя_файлаВывести список пакетов, которые больше не требуются как зависимости ("пакеты-сироты"):
$ pacman -QdtВывести список пакетов, установленных явно (explicitly) и не являющихся зависимостями для других пакетов:
$ pacman -QetДругие полезные команды можно найти в статье pacman/Советы и приёмы.
Pactree
Дерево зависимостей пакета можно узнать командой
$ pactree название_пакетаЧтобы увидеть "обратное" дерево зависимостей, т.е. список пакетов, которые сами зависят от указанного, используйте флаг pactree или утилиту whoneeds из пакета pkgtoolsAUR.
Структура базы данных
Базы данных pacman обычно размещаются в каталоге . Для каждого подключённого в файле репозитория в этом каталоге находится соответствующий файл базы данных. Сам файл представляет собой gzip-сжатый tar-архив (с расширением .db), содержащий по одному каталогу для каждого пакета. Например, для пакета содержимое каталога имеет вид:
В файле desc
хранятся мета-данные пакета — описание, список зависимостей, размер, хэш-сумма MD5 и т.д.
Очистка кэша пакетов
Pacman сохраняет скачиваемые пакеты в каталог . Старые версии пакетов и пакеты, удалённые из системы, не удаляются из этого каталога автоматически. Такой подход обладает следующими преимуществами:
Тем не менее, это означает, что время от времени необходимо чистить этот каталог самостоятельно, чтобы предотвратить его разрастание.
Скрипт из пакета удаляет из кэша старые версии пакетов, как установленных в системе, так и уже удалённых, по умолчанию оставляя только три самые свежие:
# paccache -rВключите и запустите , чтобы очистка кэша выполнялась каждую неделю автоматически.
При необходимости можно задать количество последних версий, которые нужно оставить. Команда для удаления всех версий, кроме последней:
# paccache -rk1Флаг -u
/ позволяет ограничить действие paccache только версиями пакетов, которых в системе уже нет. Например, команда удаления всех кэшированных версий удалённых пакетов:
Список возможных опций выводится командой .
В pacman есть встроеный функционал очистки кэша и удаления баз данных репозиториев, которые были заблокированы в файле . Однако pacman гораздо менее гибок по сравнению с paccache и не даёт возможности сохранить некоторое количество последних версий, просто очищая каталог кэша.
Чтобы удалить все кэшированные версии удалённых пакетов и неиспользуемые базы данных, выполните:
# pacman -ScЧтобы удалить вообще все файлы из кэша, укажите флаг очистки дважды:
# pacman -SccpkgcachecleanAUR и — две альтернативные программы для очистки кэша.
Дополнительные команды
Скачать пакет без установки:
# pacman -Sw название_пакетаУстановить пакет не из удалённого репозитория, а хранящийся локально (например, предварительно скачанный из AUR):
# pacman -U /путь/к/пакету/имя_пакета-версия.pkg.tar.zstСохранить копию локально устанавливаемого пакета в кэше pacman:
# pacman -U file:///путь/к/пакету/имя_пакета-версия.pkg.tar.zstСкачать и установить пакет из удаленного источника (но и не из репозиториев, перечисленных в конфигурационном файле pacman):
# pacman -U http://www.example.com/repo/example.pkg.tar.zstФлаг можно использовать для подавления стандартных действий -S
, и .
Pacman всегда выводит список пакетов, которые будут установлены или удалены, и спрашивает разрешение пользователя перед выполнением действия.
Причина установки
Для pacman с точки зрения причины установки пакет относится к одной из двух категорий:
При явной установке пакета можно принудительно изменить причину установки на зависимость:
# pacman -S --asdeps название_пакетаЭта команда обычно используется в случае, когда явно установленные пакеты предлагают установить дополнительные пакеты для поддержки дополнительных функций, которые пользователь может выбирать по своему усмотрению.
--asdeps
. Тогда при удалении пакетов-сирот ненужные опциональные зависимости тоже будут удаляться.
При переустановке пакета текущая причина установки не меняется.
Список явно установленных пакетов выводится командой , а пакетов-зависимостей — командой .
Чтобы изменить причину установки уже установленного пакета, выполните:
# pacman -D --asdeps название_пакетаДля противоположной операции используйте флаг .
--asdeps
и --asexplicit
в команде обновления системы, например pacman -Syu название_пакета --asdeps
. Это изменит причину установки не только для устанавливаемого пакета, но и для всех обновляемых.
Поиск пакета по названию файла
Синхронизировать базу данных файлов:
# pacman -FyНайти пакет, содержащий определённый файл (например, файл ):
Утилита pkgfile также осуществляет поиск пакетов по файлам, опираясь на свою базу данных; она обладает расширенной функциональностью по сравнению с .
Процесс установки/обновления/удаления пакета
Каждая операция ("транзакция") pacman состоит из пяти последовательных шагов, включая пред- и пост-транзакционные хуки:
Настройка
Настройки pacman находятся в файле . Подробную информацию о файле настроек можно найти в руководстве .
Глобальные параметры
Глобальные настройки pacman указываются в разделе . Помимо руководства некоторая информация о настройках из этого раздела содержится в комментариях самого файла .
Сравнение версий пакетов перед обновлением
Чтобы увидеть сравнение старых и новых версий доступных для обновления пакетов, раскомментируйте строку VerbosePkgLists
в файле . Теперь команда будет выводить примерно следующее:
Параллельная загрузка
В pacman 6.0 была добавлена функциональность параллельной загрузки пакетов. Чтобы включить эту возможность, необходимо присвоить опции в файле любое положительное значение (например, ). В противном случае, если опция не задана, то пакеты будут загружаться последовательно.
Запрет на обновление отдельных пакетов
Чтобы пропустить пакет во время обновления системы добавьте его название в параметр в разделе :
IgnorePkg=linuxЕсли необходимо пропустить обновление для нескольких пакетов, укажите названия, разделив их пробелами, или используйте несколько строк . Также можно использовать шаблоны поиска. Если нужно пропустить обновление пакета всего один раз, то лучше использовать опцию командной строки — здесь в качестве разделителя для названий пакетов используется запятая.
При необходимости обновить пакет из списка исключений всё же можно, командой pacman -S название_пакета
: pacman при этом выведет напоминание, что пакет указан в .
Запрет на обновление группы пакетов
Аналогично запрету на обновление отдельного пакета, можно запретить обновление сразу для целой группы, например:
IgnoreGroup=gnomeЗапрет на обновление файлов
Файлы, указанные в параметре , не будут изменяться в процессе установки/обновления; новые версии этих файлов будут сохраняться с расширением .pacnew.
NoUpgrade=путь/к/файлуУказать несколько файлов можно так:
NoUpgrade=путь/к/файлу1 путь/к/файлу2Запрет на установку файлов
Чтобы запретить установку файлов в определённые каталоги, перечислите их в параметре NoExtract
. Например, запрет установки юнитов systemd:
Работа с несколькими файлами настроек
Если имеется несколько конфигурационных файлов (например, основная конфигурация и дополнительная с подключённым репозиторием testing), то работу с ними можно упростить, если вынести общие пункты настроек в отдельный файл и подключать его с помощью опции :
Include = /путь/к/файлу/общих/настроекВ этом примере общие настройки вынесены в файл . Приведённую выше строку нужно добавить в оба файла настроек, основной и дополнительный.
Хуки
Системные пре- и пост-транзакционные хуки хранятся в каталоге ; pacman может выполнять хуки как из системного каталога, так и из каталогов, подключённых опцией — в файле (каталог по умолчанию — ). Название файла хука должно заканчиваться на .hook
. Хуки pacman неинтерактивны.
В частности, хуки pacman используются в связке с и для автоматического создания пользователей и файлов в процессе установки пакетов. Например, пакет требует наличия пользователя и определённых каталогов, ему принадлежащих. Хуки systemd-sysusers.hook
и вызывают команды и соответственно, когда pacman видит в пакете указания на пользователей и временные файлы.
Хуки alpm подробно описаны в руководстве .
Репозитории и зеркала
Помимо общего раздела [options] в файле также содержатся отдельные разделы для каждого из репозиториев. Репозиторий — набор пакетов, который физически находится на одном или нескольких серверах; эти сервера называются зеркалами репозитория.
Репозитории делятся на официальные и неофициальные. Порядок репозиториев в файле настроек имеет значение: если в разных репозиториях содержатся пакеты с одинаковым названием, то вне зависимости от их версий предпочтение отдаётся тому пакету, репозиторий которого ближе к началу файла. Чтобы подключённый репозиторий можно было использовать, сначала необходимо выполнить полное обновление системы.
Разделы репозиториев в файле содержат информацию о зеркалах. Список зеркал хранится в отдельном файле и подключается параметром . Например, зеркала официальных репозиториев подключаются из файла . Настройка зеркал описана в статье Mirrors.
Каталог для кэша пакетов
Pacman хранит загруженные файлы пакетов в кэше — в каталоге, указанном в опции в разделе [options] файла (по умолчанию ).
Размер этого каталога может расти со временем, даже если в нём хранятся только самые свежие версии установленных пакетов.
Если вы хотите переместить этот каталог в более удобное место, выполните одно из следующих действий:
Безопасность пакетов
Pacman использует цифровые подписи в качестве дополнительного механизма обеспечения безопасности пакетов. Настройки проверки подписей задаются параметром SigLevel
. По умолчанию в разделе задано глобальное значение , что означает проверку подписей всех пакетов без исключения. Можно задать особые правила проверки подписей для отдельных репозиториев, указав параметр SigLevel
в соответствующих разделах. Подробнее смотрите в статье pacman/Подпись пакета.
Решение проблем
Failed to commit transaction (conflicting files)
Следующее сообщение об ошибке :
ошибка: не удалось завершить транзакцию (конфликтующие файлы) пакет: '/путь/к/файлу' существует в файловой системе Обнаружены ошибки, пакеты не обновлены.означает, что при выполнении операции были обнаружены конфликтующие файлы. Pacman не будет их перезаписывать автоматически. Это не ошибка, так сделано специально.
Проблема решается тривиально. Сначала проверьте, не принадлежит ли файл другому пакету (). Если принадлежит, создайте отчет об ошибке. Если проблемный файл не нужен другим пакетам, переименуйте его и перезапустите команду обновления. Если в дальнейшем проблем не возникнет, то старый файл можно удалить.
Если программа была установлена вручную без pacman — например, при помощи команды — необходимо удалить программу и все её файлы, а затем выполнить установку при помощи pacman. Смотрите также pacman/Советы и приёмы#Поиск файлов без пакета-владельца.
Информация о каждом установленном файле хранится в файле с метаданными пакета /var/lib/pacman/local/пакет-версия/files
. При повреждении этого файла (он может быть пустым или отсутствовать) во время обновления пакета будет получена ошибка ("файл существует в файловой системе"). Обычно такие ошибки возникают во время установки или обновления всего лишь одного пакета. Вместо ручного переименования или удаления конфликтующих файлов, принадлежащих данному пакету, лучше выполнить команду , чтобы pacman принудительно перезаписал файлы, название которых совпадает с шаблоном.
Failed to commit transaction (invalid or corrupted package)
Удалите все файлы .part (частично скачанные пакеты) из кэша pacman . Причиной ошибки чаще всего является пользовательская команда в параметре файла .
# find /var/cache/pacman/pkg/ -iname "*.part" -deleteFailed to init transaction (unable to lock database)
Когда pacman собирается внести изменения в базу данных пакетов, например, при установке пакета, он создаёт файл блокировки . Это предотвращает запуск другого экземпляра pacman и таким образом спасает от возможного повреждения базы.
Если работа pacman была прервана во время внесения изменений в базу, этот файл блокировки может остаться неудалённым, что может привести к появлению такой ошибки:
ошибка: не удалось начать транзакцию (не удалось заблокировать базу данных) ошибка: не удалось заблокировать базу: Файл существуетЕсли вы уверены, что на вашей машине не запущено других экземпляров pacman, удалите этот файл блокировки:
# rm /var/lib/pacman/db.lckНе удаётся найти пакет для установки
Эта ошибка проявляется в сообщениях Not found in sync db
, или .
Удостоверьтесь, что пакет, который вы пытаетесь установить, действительно существует. Если это так, возможно, список хранящихся в репозиториях пакетов устарел. Выполните , чтобы получить новый список и обновить систему. Также убедитесь, что выбранные зеркала в рабочем состоянии, а репозитории настроены правильно.
Также есть вероятность того, что в вашей системе не включен репозиторий, содержащий нужный пакет — например, пакет находится в репозитории multilib, но не включен в файле .
Смотрите также FAQ#Почему в репозиториях есть только одна версия каждой библиотеки?
pacman падает при обновлении
Если при удалении пакетов pacman завершает свою работу с ошибкой "database write" ("запись в базу данных"), и после этого все попытки переустановки или обновления пакетов завершаются неудачей, сделайте следующее:
pacman: команда не найдена
Если является символической ссылкой, pacman в процессе самообновления попытается вместо неё создать каталог и таким образом удалит эту символическую ссылку. Из-за этого обновление завершится неудачей. В результате /usr/bin/pacman
и другие файлы из пакета исчезнут из системы.
Никогда не делайте символической ссылкой, так как этот путь находится под контролем pacman. Вместо этого используйте опцию или bind mount; подробнее смотрите #Каталог для кэша пакетов.
Если вы всё-таки столкнулись с этой проблемой и сломали свою систему, вы можете вручную извлечь содержимое из пакета, чтобы восстановить pacman, а затем корректно его переустановить; смотрите и тему на форуме для подробностей.
Переустановка pacman вручную
С помощью pacman-static
— статически скомпонованная версия pacman, которая может работать даже при отключении/повреждении системных библиотек. Это может помочь, если произошло частичное обновление и pacman больше не работает.Прикреплённый комментарий в PKGBUILD содержит ссылку на закачку двоичного файла, с помощью которого можно переустановить pacman или обновить систему целиком в случае частичного обновления.
С помощью внешнего pacman
Если не работает даже , то можно попробовать восстановить систему с помощью внешнего pacman. Простейший способ — воспользоваться archiso и указать точку монтирования в опции или . Подробнее о том, как смонтировать файловую систему для , смотрите chroot#Используя chroot.
Извлечение вручную
Даже если pacman не подаёт признаков жизни, всё ещё можно починить его вручную, загрузив последние версии пакетов и распаковав файлы в нужные места. Последовательность действий:
Если у вас имеется доступ к другой работоспособной системе с Arch Linux, полный список зависимостей можно узнать командой
$ pacman -Q $(pactree -u pacman)Возможно, вам необходимо обновить только несколько пакетов, в зависимости от серьёзности проблемы. Пример команды распаковки архива пакета:
# tar -xvpwf пакет.tar.zst -C / --exclude .PKGINFO --exclude .INSTALL --exclude .MTREE --exclude .BUILDINFOОбратите внимание на флаг , который включает интерактивный режим. Запускать распаковку неинтерактивно рискованно, потому что можно перезаписать важный файл. Также не забудьте, что пакеты нужно распаковывать в правильном порядке (сначала зависимости). На форуме рассмотрен пример процесса восстановления работоспособности pacman c несколькими неработающими пакетами-зависимостями.
Ошибка "Unable to find root device" после перезагрузки
Вероятно, при обновлении ядра был повреждён образ initramfs (например, при использовании pacman с опцией --overwrite
). Для восстановления работоспособности есть два варианта, и первый из них — использовать fallback-образ.
Когда система запустится, выполните команду пересборки образа initramfs либо из консоли, либо из терминала (для стандартного ядра ):
# mkinitcpio -p linuxЕсли этот способ не сработает, загрузитесь с Live-USB, смонтируйте корневой и загрузочный разделы, после чего сделайте chroot командой arch-chroot:
# arch-chroot /mnt # pacman -Syu mkinitcpio systemd linuxПереустановка ядра (пакета ) автоматически пересоздаст образ initramfs при помощи . Нет необходимости дополнительно вводить эту команду.
После всего этого рекомендуется выполнить , и .
Warning: current locale is invalid; using default "C" locale
Как сказано в сообщении ошибки, локаль системы настроена неправильно (смотрите статью Локали).
pacman игнорирует настройки прокси
Удостоверьтесь, что соответствующие переменные окружения ($http_proxy
, и т.д.) заданы верно. Если вы используете pacman вместе с sudo, необходимо настроить sudo на передачу переменных окружения в pacman. Также убедитесь, что настройки dirmngr в файле /etc/pacman.d/gnupg/dirmngr.conf
содержат параметр , отвечающий за использование прокси при обновлении ключей.
Как переустановить все пакеты, сохранив информацию о том, какие из них установлены явно, а какие — в качестве зависимостей?
Чтобы переустановить все пакеты из официальных репозиториев, выполните (опция -S
сохраняет причину установки по умолчанию).
После этого необходимо переустановить все пакеты из неизвестных источников, список которых можно получить командой .
Cannot open shared object file
Скорее всего, это означает, что при выполнении предыдущей операции pacman удалил или повредил разделяемые библиотеки, необходимые для него самого.
Чтобы выйти из этой ситуации, нужно вручную распаковать необходимые библиотеки в вашу файловую систему. Сперва определите, в каком пакете содержится требуемая библиотека, а затем найдите этот пакет в кэше pacman (). Распакуйте разделяемую библиотеку в файловую систему. Это позволит вам запустить pacman.
Теперь необходимо переустановить испорченный пакет. При этом обязательно используйте ключ --overwrite
, поскольку вы лишь распаковали системные файлы, но pacman об этом не знает. Pacman корректно заменит ваш файл разделяемой библиотеки на тот, что имеется в пакете.
Вот и все. Обновите оставшуюся часть системы.
Проблемы с загрузкой пакетов
Были сообщения о некоторых сетевых проблемах, которые приводят к невозможности обновления/синхронизации: , . При обычной установке Arch Linux эти проблемы не появляются, так как стандартный загрузчик файлов при этом заменяется другим (смотрите pacman/Советы и приёмы#Производительность). При установке Arch Linux в VirtualBox эта проблема также появляется, когда вы используете опцию виртуальной машины Host interface вместо NAT.
Failed retrieving file 'core.db' from mirror
Если зеркала настроены правильно, но вы получаете сообщение об ошибке , попробуйте выбрать другой сервер имён.
'local-package.pkg.tar': permission denied
Если вы пытались установить пакет в смонтированной файловой системе sshfs с помощью команды и получили такую ошибку, переместите пакет в локальный каталог и попробуйте ещё раз.
error: could not determine cachedir mount point /var/cache/pacman/pkg
Во время выполнения в chroot-окружении, например, команды , может произойти следующая ошибка:
error: could not determine cachedir mount point /var/cache/pacman/pkg error: failed to commit transaction (not enough free disk space)Такое часто случается, если каталог для chroot не являлся точкой монтирования на момент входа в chroot. Решение проблемы приведено в примечании к Установка Arch из другого дистрибутива#Скачивание базовых утилит, а объяснения и пример bind-монтирования с превращением chroot-каталога в точку монтирования можно найти в .