Difference between revisions of "Pacman troubleshooting/ru"

(Created page with "Попробуйте выполнить следующую команду:")
 
 
(43 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<languages/>
<languages/>
__TOC__
__TOC__
= Software Installation =
= Установка программ =


Various issues relating to the download and installation of software packages from the Manjaro repositories are dealt with here.
Здесь рассматриваются различные вопросы, связанные с загрузкой и установкой программных пакетов из репозиториев Manjaro.


== "Unrecognized archive format" Error ==
== Ошибка "Нераспознанный формат архива" ==


It has ocurred more than once, an update is issuing these messages in a seemingly never ending stream.
Это происходило неоднократно, обновление выдает эти сообщения в, казалось бы, бесконечном потоке.
[https://forum.manjaro.org/t/pacman-could-not-open-file-sync-files/20046 Pacman could not open file: sync files]
[https://forum.manjaro.org/t/pacman-could-not-open-file-sync-files/20046 Pacman не смог открыть файл: синхронизировать файлы].


  error: could not open file /var/lib/pacman/sync/core.db: Unrecognized archive format
  error: could not open file /var/lib/pacman/sync/core.db: Unrecognized archive format
Line 15: Line 15:
  error: could not open file /var/lib/pacman/sync/multilib.db: Unrecognized archive format
  error: could not open file /var/lib/pacman/sync/multilib.db: Unrecognized archive format


The error relates to a mismatch in the information contained in the db files at the mentioned location and the db files at the first mirror in your mirrorlist. Pacman checks a package in the database and sees if the signature file matches the one in the database. If it does not, then pacman will say the package is corrupted.
Ошибка связана с содержимым файлов db. Ошибка возникает, когда pacman получает разметку с зеркала вместо архивов базы данных.


While it sometimes is possible to fix the issue simply by deleting the files and the running a pacman update it far from every time.
Хотя иногда проблему можно решить, просто удалив файлы и запустив обновление pacman, это возможно далеко не каждый раз.


=== One recipe for fixing this ===
'''Запустите pacman-mirrors для обновления списка зеркал'''
{{UserCmd|command=sudo pacman-mirrors -c Global}}


It is mandatory to ensure that the keyrings is current. By ensuring the keyrings are in shape and then redownloading the databases we reestablish the chain of trust between the keyrings and the packages.
'''Загрузите базы данных и обновите систему'''
{{UserCmd|command=sudo pacman -Syyu}}


== Ошибка "Невозможно заблокировать базу данных" ==


'''You will have to find the correct names by looking at'''
При загрузке и установке программного обеспечения из репозиториев создается специальный файл блокировки базы данных, чтобы убедиться, что текущий процесс установки является единственным, запущенным в данный момент. В противном случае попытка одновременной установки нескольких файлов из нескольких источников может привести к повреждению загруженных файлов, конфликтам файлов или, что еще хуже, к повреждению системы. После завершения установки файл блокировки будет автоматически удален. Таким образом, эта ошибка может возникнуть по двум возможным причинам:
Browse [https://mirror.netzspielplatz.de/manjaro/packages/pool/overlay https://mirror.netzspielplatz.de/manjaro/packages/pool/overlay] for the current manjaro-keyring
and
Browse [https://mirror.netzspielplatz.de/manjaro/packages/pool/sync https://mirror.netzspielplatz.de/manjaro/packages/pool/sync] for the current archlinux-keyring


'''Replace yyyymmdd and x with the info found at the above links'''
* Другая установка все еще выполняется и еще не завершена, или
* Предыдущая попытка установки не завершилась должным образом (например, была прервана раньше времени).


sudo pacman -U https://mirror.netzspielplatz.de/manjaro/packages/pool/overlay/manjaro-keyring-yyyymmdd-x-any.pkg.tar.xz
Поэтому целесообразно сначала убедиться, что в момент возникновения ошибки не выполняется (или не выполнялась) другая установка. Убедившись в этом необходимо вручную удалить файл блокировки базы данных. Для этого откройте терминал и введите следующую команду:
sudo pacman -U https://mirror.netzspielplatz.de/manjaro/packages/pool/sync/archlinux-keyring-yyyymmdd-x-any.pkg.tar.xz
{{UserCmd|command=sudo rm /var/lib/pacman/db.lck}}


'''Remove your faulty databases'''
После этого вы сможете успешно повторить попытку установки.
sudo rm -f /var/lib/pacman/sync/*
'''Download the databases and update the system'''
sudo pacman -Syyu


== "Unable to lock database" Error ==
== Ошибки ключей ==


When downloading and installing software from the repositories, a special database lock file will be created in order to ensure that the current installation process is the only one running at that time. Otherwise, attempting to install multiple files from multiple sources simultaneously may corrupt the downloaded files, cause file conflicts - or worse still - damage your system. Once the installation has been completed, the lock file will then be automatically deleted. This error may therefore occur due to two possible reasons:
У каждого из нас есть свои уникальные подписи, используемые для подтверждения подлинности нашей личности и предотвращения мошеннических или даже вредоносных действий со стороны других людей. То же самое происходит и с программными пакетами, доступными в репозиториях программного обеспечения. Все они содержат зашифрованные коды (ключи подписи), уникальные для их разработчиков, что гарантирует их подлинность и отсутствие вредоносного характера.  


* Another installation is still taking place and has not yet finished, or
В процессе установки, после загрузки любых пакетов программного обеспечения, система сначала проверит их ключи подписи, чтобы убедиться в их подлинности, прежде чем приступить к установке. Если по какой-либо причине ключ подписи не может быть проверен, процесс установки будет прерван. Эта проблема обычно возникает по следующим причинам:
* A previous installation attempt had not finished properly (e.g. due to being aborted early)


It is therefore wise to first check to ensure that another installation is not (or had not been) in process at the time of the error. When satisfied that this is not the case, then the database lock file can be manually deleted. To do so, open up the terminal and enter the following command:
* один или несколько ключей подписи, содержащихся в базе данных вашей системы, отозваны, изменены, повреждены или устарели
* один или несколько пакетов программного обеспечения не были должным образом подписаны при размещении в репозитории


sudo rm /var/lib/pacman/db.lck
Если пакет не был подписан должным образом перед помещением в репозиторий, ответственность за исправление лежит на разработчике(-ах). Однако, поскольку эта проблема, скорее всего, связана с проблемой проверки ключа подписи в вашей системе, ее можно решить в три простых шага. Требуется рабочее подключение к сети. После того как вы открыли свой терминал:


Once done, you should now be able to successfully re-attempt your intended installation.
{{Warning|Следующие команды работают только тогда, когда ваше системное время установлено правильно!}}


{{BoxInfo|Info|Получение последних пакетов ключей может быть сделано путем просмотра каталогов пула текущих зеркал. Например, с '''https://mirror.easyname.at/manjaro/pool''' - используя '''overlay''' для ключей Manjaro и '''sync''' - для Arch и загрузив их в свою систему. Не загружайте файлы '''.sig'''.}}


== Errors about Keys ==
{{BoxInfo|Info|Те, кто работает на ARM, могут найти '''archlinuxarm-keyring''' и '''manjaro-arm-keyring''' в каталогах '''sync-arm''' и '''overlay-arm''' соответственно.}}


We all have our own unique signatures which are used to authenticate who we are and to prevent fraudulent or even malicious activities by others. This is also the case with software packages available from the software repositories. They all contain encrypted codes (signature keys) unique to their developers to ensure that they are authentic and not malicious in nature.  
'''Загрузите новые пакеты ключей''''
Перед загрузкой убедитесь, что в текущем каталоге нет пакетов ключей.
{{UserCmd|command=rm manjaro-keyring* archlinux-keyring*}}


During the installation process, once any software packages have been downloaded, your system will first check their signature keys to ensure that they are authentic prior to actually installing them. If a signature key cannot be verified for any reason, then the installation process will be aborted. This problem will usually occur due to:
Для загрузки используйте либо браузер, либо curl. Использование curl предполагает, что вы знаете правильное имя пакета, доступное с зеркала. Замените '''YYYYMMDD-R''' на доступное с зеркала.


* one or more signature keys contained in your system's database being revoked, changed, corrupted, or out of date
{{UserCmd|command=curl -O <nowiki>https://mirror.easyname.at/manjaro/pool/overlay/manjaro-keyring-YYYYMMDD-R-any.pkg.tar.xz</nowiki>}}
* one or more software packages not having been signed off properly when placed in a repository
{{UserCmd|command=curl -O <nowiki>https://mirror.easyname.at/manjaro/pool/sync/archlinux-keyring-YYYYMMDD-R-any.pkg.tar.zst</nowiki>}}


Where a package has not been signed off properly before being placed in a repository, it will be the responsibility of the developer(s) to correct this. However, as this problem will be more than likely due to a problem with your system's verification of a signiture key, this can be solved in three easy steps. Working net connection is required. Once you have opened your terminal:
'''Удалите неработающие ключи''', введя эту команду:
{{UserCmd|command=sudo rm -r /etc/pacman.d/gnupg}}


{{Warning|The following commands only work, when your system time is set correctly! }}
'''Инициализируйте связку ключей pacman''':
{{UserCmd|command=sudo pacman-key --init}}


<s>'''1. Remove old (and possibly broken) keys''' by entering this command:
'''Установите загруженные пакеты'''
Предполагая, что файлы находятся в текущем каталоге и используя подстановочный знак, чтобы не пришлось разбираться с датами и версиями - удалите пакеты после успешной установки
sudo rm -r /etc/pacman.d/gnupg
{{UserCmd|command=sudo pacman -U manjaro-keyring*.pkg.tar.xz archlinux-keyring*.pkg.tar.zst}}


'''2. Reinstall keyrings including the latest keys''':
'''Заполнить ключи''' - (необязательно, так как процесс установки сделает это сам)
{{UserCmd|command=sudo pacman-key --populate manjaro archlinux}}


sudo pacman -Sy gnupg archlinux-keyring manjaro-keyring
'''Очистите пакеты программ, загруженные во время прерванной установки''' (необязательно):
{{warning|Команда полностью очищает кэш pacman, и будет невозможно при необходимости перейти к предыдущей версии пакета. Вместо этого пакеты, вызывающие ошибки подписи, могут быть удалены по отдельности при обновлении.}}
{{UserCmd|command=sudo pacman -Sc}}


'''2. Initialize the pacman keyring''':
После этого попробуйте запустить '''sudo pacman -Syyu''' и посмотреть, были ли устранены ошибки.


sudo pacman-key --init
== Конфликтующие файлы - ''FILENAME'' exists in filesystem ==


'''4. Load the signature keys''':
''' Если вы не можете установить или обновить пакет из-за ошибки, подобной этой:'''
 
sudo pacman-key --populate archlinux manjaro
 
'''5. Refresh and update the signature keys''':
 
sudo pacman-key --refresh-keys
 
'''6. Clear out the software packages downloaded during the aborted installation''' (optional):
 
sudo pacman -Sc</s>
 
{{BoxInfo|Info|Improved version added, since it doesn't work that way above. The packages are signed and since '''/etc/pacman.d/gnupg''' has been removed, it cannot be installed due the check. Instead editing the '''/etc/pacman.conf''' and lowering the SigLevel, it would be better installing the keyrings without a check manually to overcome this problem.}}
 
'''1. Remove old (and possibly broken) keys''' by entering this command:
sudo rm -r /etc/pacman.d/gnupg
 
'''2. Initialize the pacman keyring''':
sudo pacman-key --init
 
'''3. Download the packages:'''
{{BoxInfo|Info| GPG check errors can be ignored, since it only downloads the keyring packages.}}
mkdir -pv $HOME/.cache/pkg/ && sudo pacman -Syw archlinux-keyring manjaro-keyring --cachedir $HOME/.cache/pkg/
 
'''4. Remove the signatures:'''
{{BoxInfo|Info| Signatures must be removed to avoid the automatic check of the packages.}}
rm -f $HOME/.cache/pkg/*.sig
 
'''5. Install the downloaded packages manually:
{{BoxInfo|Info|This will also trigger the populate process.}}
sudo pacman -U $HOME/.cache/pkg/*.tar.zst
 
'''6. Clear out the software packages downloaded during the aborted installation''' (optional):
{{warning|The above command clears the pacman cache completely, and one will not be able to downgrade to a previous version of a package if required. Instead packages that are causing signing errors can be removed individually when upgrading.}}
sudo pacman -Sc
'''7. Remove the custom package folder:''' (optional):
sudo rm -Rf $HOME/.cache/pkg/
 
 
After that try running '''sudo pacman -Syu''' to see if the errors were resolved.
 
== Conflicting files - ''FILENAME'' exists in filesystem ==
 
'''If you cant can't install or update a package because of an error like this:'''


  error: could not prepare transaction
  error: could not prepare transaction
Line 135: Line 91:
  Errors occurred, no packages were upgraded.
  Errors occurred, no packages were upgraded.


Then the package manager, pacman, has detected an unexpected file that already exists on the disk.
Затем менеджер пакетов pacman обнаружил неожиданный файл, который уже существует на диске.
 
'''Why is this happening?'''
 
By design pacman will '''not''' overwrite files that already exist. This is a design feature, not a flaw - package managers are designed to keep track of installed files.
 
This issue normally happens because you've manually added, copied, or created a file. It can also happen when you install software using a downloaded executable, run a make install, or use a third-party package system such as conda. It also occurs when you install an AUR package which installs files that conflict with a repo package.
 
When using a third-party installer you should always specify an alternative installation location, such as under your home directory, or under /opt or /usr/local/. Never install directly under / or /usr.
 
'''How can I fix this?'''
 
The first step is to identify which, if any, package owns the file. This can be easily done with:


pacman -Qo /path/to/file
'''Почему это происходит?'''


If this identifies a conflicting package you can decide to remove it with pacman -R. If no package is identified you can delete the file (or move it to a backup location).
По своей конструкции pacman '''не''' перезаписывает существующие файлы. Это особенность разработки, а не недостаток - менеджеры пакетов предназначены для отслеживания установленных файлов.


'''Where can I read more?'''
Обычно эта проблема возникает, когда вы вручную добавляете, копируете или создаете файл. Это также может произойти, если вы устанавливаете программное обеспечение с помощью загруженного исполняемого файла, выполняете make install или используете пакетную систему сторонних производителей, например conda. Это также происходит при установке пакета AUR, устанавливающий файлы, конфликтующие с пакетом из репозитория.


This post was inspired by (and adapted from):
При использовании сторонней программы установки всегда указывайте альтернативное место установки, например, в вашем домашнем каталоге или в каталоге /opt или /usr/local/. Никогда не устанавливайте непосредственно в / или /usr.


https://wiki.archlinux.org/title/Pacman#%22Failed_to_commit_transaction_(conflicting_files)%22_error
'''Как мне это исправить?'''


The above post also has links to further reading.
Первый шаг - определить, какой пакет, если таковой имеется, владеет файлом. Это можно легко сделать с помощью:


== "Configuration file...not recognized" Error ==
{{UserCmd|command=pacman -Qo /путь/к/файлу}}


Manjaro's package manager - '''[[pacman]]''' - uses a file called ''mirrorlist'' to tell it the internet addresses of the Manjaro servers in order to download updates and software applications from them. This error will therefore occur if one or more server addresses contained in the mirrorlist file have not been listed properly, resulting in pacman being unable to connect to them. Another tell-tale sign is that this problem will also be encountered immediately after:
Если при этом обнаружится конфликтующий пакет, то вы можете решить удалить его с помощью команды pacman -R. Если пакет не обнаружен, вы можете удалить файл (или переместить его в резервное место).


* Installing Manjaro and editing the mirrorlist file during installation, or
'''Где можно прочитать больше?'''
* Editing the mirrorlist file at a later time.


See the [[Change to a Different Download Server]] guide for more detailed information on how to correctly select and enable another Manjaro server for downloading.
Этот пост был вдохновлен (и адаптирован из):


[https://wiki.archlinux.org/title/Pacman_(Русский)#Failed_to_commit_transaction_(conflicting_files) Pacman - Решение проблем]


== "GPGME error: No data" Error ==
В приведенном выше сообщении также есть ссылки на дальнейшее чтение.


The most likely cause of this issue is that an error or corruption has been detected by ''pacman'' in one or more software packages being downloaded. Package signatures and checksums are used to verify the validity of downloaded software, and should they fail, the installation attempt will be aborted to protect your system until the matter is resolved.
== Ошибка "Файл конфигурации...не распознан" ==


Менеджер пакетов Manjaro - '''[[pacman]]''' - использует файл под названием ''mirrorlist'', сообщающий ему интернет-адреса серверов Manjaro для загрузки с них обновлений и программ. Эта ошибка возникает, если один или несколько адресов серверов, содержащихся в файле mirrorlist, не были указаны правильно, в результате чего pacman не может подключиться к ним. Еще одним признаком является то, что эта проблема также возникнет сразу после:


=== Option 1: Basic Resolution ===
* Установки Manjaro и редактирования файла mirrorlist во время установки, или
* Редактирования файла mirrorlist позднее.


To resolve this issue, first follow the basic procedure provided below. If this does not work, then there is a more comprehensive procedure available.
Смотрите руководство [[Change to a Different Download Server|Переход на другой сервер загрузки]] для более подробной информации о том, как правильно выбрать и включить другой сервер Manjaro для загрузки.




1. Download the package databases and update your system:
== Ошибка "GPGME error: No data" ==


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


2. Clear out the software packages downloaded during the aborted installation by entering the command:


sudo pacman -Sc
=== Вариант 1: Базовое разрешение ===


3. Re-attempt the aborted download.
Чтобы решить эту проблему, сначала выполните основную процедуру, приведенную ниже. Если это не сработает, можно воспользоваться более комплексной процедурой.


=== Option 2: Comprehensive Resolution ===


If the basic proceedure still does not resolve the matter, further steps are available:
1. Загрузите базы данных пакетов и обновите систему:


{{UserCmd|command=sudo pacman -Syyu}}


1. Resynchronise with the Manjaro servers to ensure that everything is up to date by entering the command:
2. Очистите пакеты программного обеспечения, загруженные во время прерванной установки, введя команду:  


  sudo pacman -Syy
  {{UserCmd|command=sudo pacman -Sc}}


2. Refresh and update the signature keys by entering the command:
3. Повторите попытку прерванной загрузки.


sudo pacman-key --refresh-keys
=== Вариант 2: Комплексное решение ===


3. Reload the signature keys by entering the command:
Если основная процедура не приведет к решению вопроса, можно предпринять дальнейшие шаги:


sudo pacman-key --populate archlinux manjaro
1. Выполните повторную синхронизацию с серверами Manjaro, чтобы убедиться, что все данные обновлены, введя команду:
{{UserCmd|command=sudo pacman -Syy}}


4. Clear out the software packages downloaded during the aborted installation by entering the command:
2. Обновите ключи подписей, введя команду:
{{UserCmd|command=sudo pacman-key --refresh-keys}}


sudo pacman -Sc
3. Перезагрузите ключи подписей, введя команду:
{{UserCmd|command=sudo pacman-key --populate archlinux manjaro}}


5. Re-attempt the aborted download.
4. Очистите пакеты программного обеспечения, загруженные во время прерванной установки, введя команду:
{{UserCmd|command=sudo pacman -Sc}}


5. Повторите попытку прерванной загрузки.


If the error still persists, then it is recommended to '''[[Change to a Different Download Server]]'''.
Если ошибка не исчезла, то рекомендуется '''[[Change to a Different Download Server/ru|переход на другой сервер загрузки]]''''.




== "keyserver refresh failed: No dirmngr" Error ==
== Ошибка "keyserver refresh failed: No dirmngr" ==


Попробуйте выполнить следующую команду:
Попробуйте выполнить следующую команду:
{{UserCmd|command=sudo dirmngr <nowiki></dev/null</nowiki>}}


sudo dirmngr </dev/null
= Смотрите также =
 
 
= See Also =


* '''[[Change to a Different Download Server|Переход на другой сервер загрузки]]'''
* '''[[Change to a Different Download Server/ru|Переход на другой сервер загрузки]]'''
* '''[[Pacman-mirrors|Справочное руководство по pacman-mirrors]]'''
* '''[[Pacman-mirrors/ru|Справочное руководство по pacman-mirrors]]'''
* '''[https://wiki.archlinux.org/index.php/Pacman#Troubleshooting Arch wiki для более полного устранения неполадок]'''
* '''[https://wiki.archlinux.org/index.php/Pacman_(Русский)#Решение_проблем Arch wiki для более полного устранения неполадок]'''
[[Category:Contents Page{{#translation:}}]]
[[Category:Contents Page{{#translation:}}]]

Latest revision as of 06:45, 6 July 2023

Other languages:
English • ‎Türkçe • ‎español • ‎français • ‎русский

Установка программ

Здесь рассматриваются различные вопросы, связанные с загрузкой и установкой программных пакетов из репозиториев Manjaro.

Ошибка "Нераспознанный формат архива"

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

error: could not open file /var/lib/pacman/sync/core.db: Unrecognized archive format
error: could not open file /var/lib/pacman/sync/extra.db: Unrecognized archive format
error: could not open file /var/lib/pacman/sync/community.db: Unrecognized archive format
error: could not open file /var/lib/pacman/sync/multilib.db: Unrecognized archive format

Ошибка связана с содержимым файлов db. Ошибка возникает, когда pacman получает разметку с зеркала вместо архивов базы данных.

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

Запустите pacman-mirrors для обновления списка зеркал

user $ sudo pacman-mirrors -c Global COPY TO CLIPBOARD


Загрузите базы данных и обновите систему

user $ sudo pacman -Syyu COPY TO CLIPBOARD


Ошибка "Невозможно заблокировать базу данных"

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

  • Другая установка все еще выполняется и еще не завершена, или
  • Предыдущая попытка установки не завершилась должным образом (например, была прервана раньше времени).

Поэтому целесообразно сначала убедиться, что в момент возникновения ошибки не выполняется (или не выполнялась) другая установка. Убедившись в этом необходимо вручную удалить файл блокировки базы данных. Для этого откройте терминал и введите следующую команду:

user $ sudo rm /var/lib/pacman/db.lck COPY TO CLIPBOARD


После этого вы сможете успешно повторить попытку установки.

Ошибки ключей

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

В процессе установки, после загрузки любых пакетов программного обеспечения, система сначала проверит их ключи подписи, чтобы убедиться в их подлинности, прежде чем приступить к установке. Если по какой-либо причине ключ подписи не может быть проверен, процесс установки будет прерван. Эта проблема обычно возникает по следующим причинам:

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

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


Warning
Следующие команды работают только тогда, когда ваше системное время установлено правильно!


Info
Получение последних пакетов ключей может быть сделано путем просмотра каталогов пула текущих зеркал. Например, с https://mirror.easyname.at/manjaro/pool - используя overlay для ключей Manjaro и sync - для Arch и загрузив их в свою систему. Не загружайте файлы .sig.


Info
Те, кто работает на ARM, могут найти archlinuxarm-keyring и manjaro-arm-keyring в каталогах sync-arm и overlay-arm соответственно.

Загрузите новые пакеты ключей' Перед загрузкой убедитесь, что в текущем каталоге нет пакетов ключей.

user $ rm manjaro-keyring* archlinux-keyring* COPY TO CLIPBOARD


Для загрузки используйте либо браузер, либо curl. Использование curl предполагает, что вы знаете правильное имя пакета, доступное с зеркала. Замените YYYYMMDD-R на доступное с зеркала.

user $ curl -O https://mirror.easyname.at/manjaro/pool/overlay/manjaro-keyring-YYYYMMDD-R-any.pkg.tar.xz COPY TO CLIPBOARD


user $ curl -O https://mirror.easyname.at/manjaro/pool/sync/archlinux-keyring-YYYYMMDD-R-any.pkg.tar.zst COPY TO CLIPBOARD


Удалите неработающие ключи, введя эту команду:

user $ sudo rm -r /etc/pacman.d/gnupg COPY TO CLIPBOARD


Инициализируйте связку ключей pacman:

user $ sudo pacman-key --init COPY TO CLIPBOARD


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

user $ sudo pacman -U manjaro-keyring*.pkg.tar.xz archlinux-keyring*.pkg.tar.zst COPY TO CLIPBOARD


Заполнить ключи - (необязательно, так как процесс установки сделает это сам)

user $ sudo pacman-key --populate manjaro archlinux COPY TO CLIPBOARD


Очистите пакеты программ, загруженные во время прерванной установки (необязательно):

Warning
Команда полностью очищает кэш pacman, и будет невозможно при необходимости перейти к предыдущей версии пакета. Вместо этого пакеты, вызывающие ошибки подписи, могут быть удалены по отдельности при обновлении.
user $ sudo pacman -Sc COPY TO CLIPBOARD


После этого попробуйте запустить sudo pacman -Syyu и посмотреть, были ли устранены ошибки.

Конфликтующие файлы - FILENAME exists in filesystem

Если вы не можете установить или обновить пакет из-за ошибки, подобной этой:

error: could not prepare transaction
error: failed to commit transaction (conflicting files)
libname: /insert/file/name/here exists in filesystem
Errors occurred, no packages were upgraded.

Затем менеджер пакетов pacman обнаружил неожиданный файл, который уже существует на диске.

Почему это происходит?

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

Обычно эта проблема возникает, когда вы вручную добавляете, копируете или создаете файл. Это также может произойти, если вы устанавливаете программное обеспечение с помощью загруженного исполняемого файла, выполняете make install или используете пакетную систему сторонних производителей, например conda. Это также происходит при установке пакета AUR, устанавливающий файлы, конфликтующие с пакетом из репозитория.

При использовании сторонней программы установки всегда указывайте альтернативное место установки, например, в вашем домашнем каталоге или в каталоге /opt или /usr/local/. Никогда не устанавливайте непосредственно в / или /usr.

Как мне это исправить?

Первый шаг - определить, какой пакет, если таковой имеется, владеет файлом. Это можно легко сделать с помощью:

user $ pacman -Qo /путь/к/файлу COPY TO CLIPBOARD


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

Где можно прочитать больше?

Этот пост был вдохновлен (и адаптирован из):

Pacman - Решение проблем

В приведенном выше сообщении также есть ссылки на дальнейшее чтение.

Ошибка "Файл конфигурации...не распознан"

Менеджер пакетов Manjaro - pacman - использует файл под названием mirrorlist, сообщающий ему интернет-адреса серверов Manjaro для загрузки с них обновлений и программ. Эта ошибка возникает, если один или несколько адресов серверов, содержащихся в файле mirrorlist, не были указаны правильно, в результате чего pacman не может подключиться к ним. Еще одним признаком является то, что эта проблема также возникнет сразу после:

  • Установки Manjaro и редактирования файла mirrorlist во время установки, или
  • Редактирования файла mirrorlist позднее.

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


Ошибка "GPGME error: No data"

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


Вариант 1: Базовое разрешение

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


1. Загрузите базы данных пакетов и обновите систему:

user $ sudo pacman -Syyu COPY TO CLIPBOARD


2. Очистите пакеты программного обеспечения, загруженные во время прерванной установки, введя команду:

user $ sudo pacman -Sc COPY TO CLIPBOARD


3. Повторите попытку прерванной загрузки.

Вариант 2: Комплексное решение

Если основная процедура не приведет к решению вопроса, можно предпринять дальнейшие шаги:

1. Выполните повторную синхронизацию с серверами Manjaro, чтобы убедиться, что все данные обновлены, введя команду:

user $ sudo pacman -Syy COPY TO CLIPBOARD


2. Обновите ключи подписей, введя команду:

user $ sudo pacman-key --refresh-keys COPY TO CLIPBOARD


3. Перезагрузите ключи подписей, введя команду:

user $ sudo pacman-key --populate archlinux manjaro COPY TO CLIPBOARD


4. Очистите пакеты программного обеспечения, загруженные во время прерванной установки, введя команду:

user $ sudo pacman -Sc COPY TO CLIPBOARD


5. Повторите попытку прерванной загрузки.

Если ошибка не исчезла, то рекомендуется переход на другой сервер загрузки'.


Ошибка "keyserver refresh failed: No dirmngr"

Попробуйте выполнить следующую команду:

user $ sudo dirmngr </dev/null COPY TO CLIPBOARD


Смотрите также