Что такое «dist-upgrade» и почему он обновляется больше, чем «upgrade»?

395

Мне было интересно, почему upgradeиногда не хочется обновлять определенные части системы, а dist-upgradeделает. Вот пример после запуска apt-get upgrade:

apt-get upgrade:

rimmer@rimmer-Lenovo-IdeaPad-S10-2:~$ sudo apt-get upgrade
Reading package lists... Done
Building dependency tree       
Reading state information... Done
The following packages have been kept back:
  linux-generic linux-headers-generic linux-image-generic
0 upgraded, 0 newly installed, 0 to remove and 3 not upgraded.

по сравнению с apt-get dist-upgrade:

rimmer@rimmer-Lenovo-IdeaPad-S10-2:~$ sudo apt-get dist-upgrade
Reading package lists... Done
Building dependency tree       
Reading state information... Done
Calculating upgrade... Done
The following NEW packages will be installed:
  linux-headers-3.0.0-13 linux-headers-3.0.0-13-generic
  linux-image-3.0.0-13-generic
The following packages will be upgraded:
  linux-generic linux-headers-generic linux-image-generic
3 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.
Need to get 48.5 MB of archives.
After this operation, 215 MB of additional disk space will be used.
Do you want to continue [Y/n]?

Другими словами, почему это не может быть выполнено upgrade?

Ричард Родригес
источник

Ответы:

328

Из apt-getруководства :

upgrade
   upgrade is used to install the newest versions of all packages
   currently installed on the system from the sources enumerated in
   /etc/apt/sources.list. Packages currently installed with new
   versions available are retrieved and upgraded; under no
   circumstances are currently installed packages removed, or packages
   not already installed retrieved and installed. New versions of
   currently installed packages that cannot be upgraded without
   changing the install status of another package will be left at
   their current version. An update must be performed first so that
   apt-get knows that new versions of packages are available.

dist-upgrade
   dist-upgrade in addition to performing the function of upgrade,
   also intelligently handles changing dependencies with new versions
   of packages; apt-get has a "smart" conflict resolution system, and
   it will attempt to upgrade the most important packages at the
   expense of less important ones if necessary. So, dist-upgrade
   command may remove some packages. The /etc/apt/sources.list file
   contains a list of locations from which to retrieve desired package
   files. See also apt_preferences(5) for a mechanism for overriding
   the general settings for individual packages.

И с более новым aptинструментом, доступным с 14.04 года:

full-upgrade
   full-upgrade performs the function of upgrade but may also remove
   installed packages if that is required in order to resolve a
   package conflict.

В вашем конкретном случае, я вижу, что , например, linux-headersпредставляет собой виртуальный пакет , который обеспечивается как linux-headers-3.0.0-12и linux-headers-3.0.0-13и это звучит как вид установки и удаления обрабатываемого пакета dist-upgrade, но не upgrade.

jcollado
источник
4
Я не вижу full-upgradeв качестве опции до apt-get14.04.1.
Нобар
Я не знал aptни того, ни другого, но, похоже, это совершенно другая команда, согласно странице руководства, которую он связал
BlueWizard,
18
@nobar Вы не видите, потому что это вариант, aptа не из apt-get... :-) Попробуйте man apt.
Хастур
Хорошо, я искал, и самая ранняя ссылка, которую я нашел, - это Ubuntu 15.10 (вышедшая в конце 2014 года, что вполне оправданно при тестировании Джесси). Manpages.ubuntu.com/manpages/wily/en/man8/apt.8.html
Z boson
6
@Zboson Ага, а 14.04 вышло не в 2011 году, а в апреле 2014 года ... видите шаблон?
tgies
137

apt-get upgradeограничивается случаем, когда пакеты должны быть заменены более новыми версиями, но нет необходимости добавлять или удалять пакеты. Например, новую версию Firefox можно установить с помощью apt-get upgrade.

Однако apt-get upgradeбудет отказываться работать, когда есть обновления или удаления, необходимые для обновленных версий. Например, когда у вас linux-image-3.2.0-10-genericустановлено и linux-image-3.2.0-11-genericотображается ядро , linux-image-genericпакет обновляется в зависимости от более новой версии. Для того, чтобы установить новое ядро, вам нужно запустить apt-get dist-upgrade.

Обратите внимание, как an apt-get upgradeскажет, что пакеты ядра были held back. Это сигнал для использования apt-get dist-upgrade.

pablomme
источник
2
Отлично! : D Еще два вопроса ... что использует графический менеджер обновлений в Ubuntu? Что рекомендуется?
THpubs
11
Графическая утилита, update-managerне использует apt-getнапрямую; вместо этого он работает с бэкэндом aptdaemon. Стандартные возможности update-managerпредставляют собой сочетание режимов upgradeи : он может добавлять, но не удалять пакеты - он вызывает инструмент «Частичное обновление», когда требуется удаление. При использовании командной строки используйте . Если вы видите, что он сообщает, что пакеты были «задержаны», запустите, чтобы забрать оставшиеся обновления. dist-upgradeapt-getapt-get upgradeapt-get dist-upgrade
Пабломе
33

В основном, обновление будет обновлять только существующие пакеты с одной версии на другую. Он не будет устанавливать или удалять пакеты, даже если это необходимо для обновления других. В случае обновлений ядра обновление пакета linux-generic требует установки нового пакета linux-3.0.0-13-generic, а поскольку обновление отказывается устанавливать или удалять пакеты, оно отказывается обновлять linux-generic.

Иногда различные несовместимости между пакетами требуют удаления некоторых пакетов для обновления других, что также требует dist-upgrade. Обновления ядра всегда требуют dist-upgrade из-за того, как они обрабатываются. Вместо того, чтобы обновлять пакет ядра, каждый раз создается совершенно новый пакет ядра, и метапакет ядра обновляется в зависимости от нового пакета ядра, а не от старого. Это было сделано для того, чтобы вы сохранили старые версии ядра, чтобы в случае проблем с загрузкой нового ядра, вы могли выбрать старое из меню загрузки и выполнить восстановление.

psusi
источник
2
Лучший суть. Тем не менее, как сохранить определенный пакет?
0xC0000022L
11

Команда apt-get upgradeобычно устанавливает обновления (или исправления) только для установленных на данный момент пакетов. Как правило, с помощью этой команды устанавливается новая версия Mozilla Firefox .

Однако apt-get upgradeбудет НЕ вообще устанавливать новые версии, где (требуется , включая удаление пакетов или обновление GRUB) значительные изменения. Например, если доступно новое ядро ​​Linux (linux-image-3.xx-xx-generic и т. Д.), Пакет не будет установлен.

Чтобы установить новое ядро, вам нужно будет запустить apt-get dist-upgrade. При запуске вы получите уведомление apt-get upgradeо том, что некоторые пакеты были задержаны. Это ваша реплика для использования apt-get dist-upgrade.

david6
источник
12
Это вводит в заблуждение. dist-upgradeне будет обновляться до нового выпуска, если только он sources.listне был изменен соответствующим образом (и даже тогда это не поддерживается в Ubuntu). Когда новое ядро ​​установлено с dist-upgrade, это не новая версия Ubuntu . Это просто новый пакет. Кроме того, утверждение «Требуется обновление GRUB» является ложным. sudo apt-get upgradeвполне способен обновлять пакеты в ситуации, когда GRUB должен быть обновлен, при условии, что пакеты не удалены, а новые пакеты установлены. update-grubзапускается автоматически, как всегда.
Элия ​​Каган
2
Вы должны написать свой собственный ответ, так как это не добавляет ясности моему.
Давид6
2
Помимо того, что упомянул Элия, важно то, что apt-get upgradeвы не будете удалять или добавлять пакеты. Если для исправления пакета требуется новый пакет, обновление будет отложено. Ответ Пабломме , который вы пересмотрели, чтобы он был менее точным, лучше, и я бы посоветовал читателям перейти к нему.
Чан-Хо Су
1
Исправление: apt-get upgradeникогда не будет устанавливать или удалять какие-либо пакеты. Обновления ядра упаковываются как новые пакеты и, как следствие, apt-get upgradeникогда не обновят ядро. Тот факт, что обновление ядра вносит «серьезные» изменения, такие как конфигурация GRUB, не является причиной разницы между upgradeи dist-upgrade.
Микко Ранталайнен,
1

Ваш лучший вариант:

apt full-upgrade

- которая автоматически обрабатывает зависимости при обновлении пакетов; в то время как:

apt upgrade

- НЕ обрабатывает зависимости автоматически при обновлении пакетов.

- duBtrotterS

Бретт Мэддокс-Страуд
источник