Wat is "dist-upgrade" en waarom upgrade het meer dan "upgrade"?

Ik vroeg me af waarom upgrade soms bepaalde delen van het systeem niet wil upgraden, terwijl dist-upgrade dat wel doet. Hier's een voorbeeld na het uitvoeren van 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.

tegenover 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]?

Met andere woorden, waarom kan dit niet worden uitgevoerd door upgrade?

Oplossing

Van apt-get handleiding:

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.

En met de nieuwere apt tool die vanaf 14.04 beschikbaar is:

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.

In uw specifieke geval zie ik bijvoorbeeld dat linux-headers een virtueel pakket is dat wordt geleverd door zowel linux-headers-3.0.0-12 als linux-headers-3.0.0-13 en dat klinkt als het soort pakketinstallatie en -verwijdering dat wordt afgehandeld door dist-upgrade, maar niet door upgrade.

Commentaren (7)

apt-get upgrade is beperkt tot het geval waarin pakketten moeten worden vervangen door nieuwere versies, maar geen pakket hoeft te worden toegevoegd of verwijderd. Een nieuwe versie van Firefox, bijvoorbeeld, zou installeerbaar moeten zijn met apt-get upgrade.

Echter apt-get upgrade zal weigeren te werken als er toevoegingen of verwijderingen nodig zijn door de bijgewerkte versies. Bijvoorbeeld, wanneer u kernel linux-image-3.2.0-10-generic heeft geïnstalleerd en linux-image-3.2.0-11-generic verschijnt, dan wordt het linux-image-generic pakket geupdate om afhankelijk te zijn van de nieuwere versie. Om de nieuwe kernel te installeren, moet u apt-get dist-upgrade uitvoeren.

Merk op dat een apt-get upgrade zal zeggen dat de kernel pakketten zijn achtergehouden. Dat is het teken om apt-get dist-upgrade te gebruiken.

Commentaren (2)

In principe zal upgrade alleen bestaande pakketten opwaarderen van de ene versie naar de andere. Het zal geen pakketten installeren of verwijderen, zelfs als dit nodig is om andere pakketten te upgraden. In het geval van kernel updates, vereist het upgraden van het linux-generic pakket de installatie van het nieuwe linux-3.0.0-13-generic pakket, en aangezien upgrade weigert om pakketten te installeren of te verwijderen, weigert het om linux-generic te upgraden.

Soms zullen verschillende incompatibiliteiten tussen pakketten vereisen dat sommige pakketten verwijderd worden om andere te kunnen upgraden, en dat zal ook dist-upgrade vereisen. Kernel updates zullen altijd een dist-upgrade vereisen omwille van de manier waarop ze behandeld worden. In plaats van een kernelpakket dat geüpdatet wordt, wordt elke keer een volledig nieuw kernelpakket aangemaakt, en het kernel metapakket wordt geüpdatet zodat het afhangt van het nieuwe kernelpakket in plaats van het oude. Dit werd gedaan om de oude kernelversies te bewaren zodat, indien er een probleem is met het booten van de nieuwe kernel, u de oude kunt kiezen in het bootmenu en herstellen.

Commentaren (1)