Примечание о возможном дубликате:
AFAIK, это не дубликат Как разрешить неудовлетворенные зависимости после добавления PPA? в противном случае, докажите это, решив тестовую задачу, о которой я упоминаю ниже, используя любой ответ оттуда.
Фон:
Я сталкивался с этой проблемой до того, как исправить установку wine на Ubuntu 14.04.3LTS 64 bit . Это было решено путем ручного / человеческого анализа всех рекурсивных зависимостей целевого пакета ( wine).
Воспроизведите проблему (контрольный пример):
Давайте создадим ту же ситуацию, просто упрощая всего 1 пакет с неприятностями.
- Установите свежую Ubuntu 14.04 на VirtualBox.
- Откройте
software-properties-gtkи включитеbackportsрепозиторий. Получить список последних пакетов
sudo apt-get updateЗапустите,
apt-get -s install wineчтобы подтвердить, чтоwineможно установить.Установите тревожный пакет
libcgmanager0из бэкпорта$ apt-cache policy libcgmanager0 libcgmanager0: Installed: 0.24-0ubuntu5 Candidate: 0.24-0ubuntu7.5 Version table: 0.39-2ubuntu2~ubuntu14.04.1 0 100 http://dz.archive.ubuntu.com/ubuntu/ trusty-backports/main amd64 Packages 0.24-0ubuntu7.5 0 500 http://dz.archive.ubuntu.com/ubuntu/ trusty-updates/main amd64 Packages 0.24-0ubuntu7.1 0 500 http://security.ubuntu.com/ubuntu/ trusty-security/main amd64 Packages *** 0.24-0ubuntu5 0 500 http://dz.archive.ubuntu.com/ubuntu/ trusty/main amd64 Packages 100 /var/lib/dpkg/statusПринудительно
aptустановитьlibcgmanager0версию0.39-2ubuntu2~ubuntu14.04.1sudo apt-get install libcgmanager0=0.39-2ubuntu2~ubuntu14.04.1
Теперь мы попадаем в ту же ситуацию, что и пользователь, из упомянутого вопроса в фоновом режиме, установка Wine не выполняется с неудовлетворенной зависимостью, показывая только пакеты зависимостей первого уровня.
apt-get -s install wineReading package lists... Done Building dependency tree Reading state information... Done Some packages could not be installed. This may mean that you have requested an impossible situation or if you are using the unstable distribution that some required packages have not yet been created or been moved out of Incoming. The following information may help to resolve the situation: The following packages have unmet dependencies: wine : Depends: wine1.6 but it is not going to be installed E: Unable to correct problems, you have held broken packages.apt-get -s install wine1.6Reading package lists... Done Building dependency tree Reading state information... Done Some packages could not be installed. This may mean that you have requested an impossible situation or if you are using the unstable distribution that some required packages have not yet been created or been moved out of Incoming. The following information may help to resolve the situation: The following packages have unmet dependencies: wine1.6 : Depends: wine1.6-i386 (= 1:1.6.2-0ubuntu4) E: Unable to correct problems, you have held broken packages.apt-get -s install wine1.6-i386Reading package lists... Done Building dependency tree Reading state information... Done Some packages could not be installed. This may mean that you have requested an impossible situation or if you are using the unstable distribution that some required packages have not yet been created or been moved out of Incoming. The following information may help to resolve the situation: The following packages have unmet dependencies: wine1.6-i386:i386 : Depends: libglu1-mesa:i386 but it is not going to be installed or libglu1:i386 Depends: libgphoto2-6:i386 (>= 2.5.2) but it is not going to be installed Depends: libgphoto2-port10:i386 (>= 2.5.2) but it is not going to be installed Recommends: libsane:i386 but it is not going to be installed E: Unable to correct problems, you have held broken packages.
Непрактично следовать зависимостям apt-get installодин за другим.
Идеальное решение:
Настоящая проблема здесь
aptНе удалось установитьlibcgmanager0:i386версию,0.39-2ubuntu2~ubuntu14.04.1поскольку репозиторий backports имеет более низкий приоритет,100чем версия0.24-0ubuntu7.5изupdatesрепозитория с500aptне удалось установитьlibcgmanager0:i386версию,0.24-0ubuntu7.5потому чтоlibcgmanager0:amd64установлена с другой версией0.39-2ubuntu2~ubuntu14.04.1
Самое быстрое решение - принудительно установить ту же версию i386 из бэкпортов.
sudo apt-get install libcgmanager0:i386=0.39-2ubuntu2~ubuntu14.04.1
или понизить его (amd64) до любой версии из обычных репозиториев
sudo apt-get install libcgmanager0=0.24-0ubuntu7.5
Способы / инструменты, которые я пробовал:
- Отключение PPA не имеет отношения к проблеме.
- Использование
aptitudeв интерактивном режиме, приносит только решения с большим количеством удалений ( > 200 !!! ). - Используйте
apt-get installвручную, следуя дереву зависимостей. Непрактично, поскольку зависимости первого и второго уровня не привели к значимым сообщениям о конфликте. debfosterможет генерировать рекурсивные зависимости, но только для уже установленного пакета. Однакоwineеще не установлен.
Тема / Мои интересы:
Допустим, я хочу установить wine, не зная о проблеме libcgmanager0пакета (или о том, libcgmanager0:amd64=0.39-2ubuntu2~ubuntu14.04.1что уже установлено).
Я ищу способ отладки или способ узнать название пакета, вызывающего беспокойство, и быстро понять, что происходит.
Как отладить неудовлетворенные проблемы зависимостей в целом?
Возможно, в
dpkg/apt/aptitudeпоявятся новые опции, которые отслеживают преобразователь внутренних зависимостей. Это может показатьlibcgmanager0на выходе.Если нет канонического ответа на этот вопрос, может ли кто-нибудь показать мне лучший способ создания списка рекурсивных зависимостей или смоделировать средство разрешения зависимостей с более подробной информацией, которая может помочь решить проблему?
Почему все зависимости? Потому что я хочу проверить вывод приведенных ниже команд для всех пакетов одновременно.
apt-cache policy <all-dependencies>apt-get -s install <all-dependencies>
libcgmanagerв зависимости, а в зависимости? Вы упомянули рекурсивный список зависимостей. Ты пробовал apt-rdepends?
wine(или другой уязвимый пакет) с -o Debug::pkgProblemResolver=yes?
backportsверсия?