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

Мне было интересно, почему 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 ?

Из руководства 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 .

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 .

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

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

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

Команда 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 .