Was ist "dist-upgrade" und warum aktualisiert es mehr als "upgrade"?

Ich habe mich gefragt, warum upgrade manchmal bestimmte Teile des Systems nicht aktualisieren will, während dist-upgrade dies tut. Hier's ein Beispiel nach dem Ausführen von 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.

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

Mit anderen Worten, warum kann dies nicht mit upgrade durchgeführt werden?

Lösung

Aus apt-get Handbuch:

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.

Und mit dem neueren apt Werkzeug, das ab 14.04 verfügbar ist:

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 Ihrem speziellen Fall sehe ich zum Beispiel, dass linux-headers ein virtuelles Paket ist, das sowohl von linux-headers-3.0.0-12 als auch von linux-headers-3.0.0-13 bereitgestellt wird, und das klingt nach der Art von Paketinstallation und -entfernung, die von dist-upgrade, aber nicht von upgrade gehandhabt wird.

Kommentare (7)

apt-get upgrade ist auf den Fall beschränkt, dass Pakete durch neuere Versionen ersetzt werden sollen, aber kein Paket hinzugefügt oder entfernt werden muss. Eine neue Version von Firefox, zum Beispiel, sollte mit apt-get upgrade installiert werden können.

Allerdings wird apt-get upgrade sich weigern zu funktionieren, wenn es Ergänzungen oder Entfernungen gibt, die von den aktualisierten Versionen benötigt werden. Wenn Sie zum Beispiel den Kernel linux-image-3.2.0-10-generic installiert haben und linux-image-3.2.0-11-generic erscheint, wird das Paket linux-image-generic aktualisiert, um von der neueren Version abzuhängen. Um den neuen Kernel zu installieren, müssen Sie apt-get dist-upgrade ausführen.

Beachten Sie, dass apt-get upgrade sagt, dass die Kernel-Pakete zurückgehalten wurden. Das ist das Stichwort für die Verwendung von apt-get dist-upgrade.

Kommentare (2)

Grundsätzlich werden mit upgrade nur vorhandene Pakete von einer Version auf eine andere aktualisiert. Es wird keine Pakete installieren oder entfernen, selbst wenn dies erforderlich ist, um andere zu aktualisieren. Im Fall von Kernel-Aktualisierungen erfordert das Upgrade des Pakets linux-generic die Installation des neuen Pakets linux-3.0.0-13-generic, und da upgrade sich weigert, Pakete zu installieren oder zu entfernen, weigert es sich, linux-generic zu aktualisieren.

Manchmal erfordern verschiedene Inkompatibilitäten zwischen Paketen, dass einige Pakete entfernt werden müssen, um andere zu aktualisieren, und das erfordert ebenfalls ein dist-upgrade. Kernel-Aktualisierungen werden aufgrund der Art und Weise, wie sie gehandhabt werden, immer ein dist-upgrade erfordern. Anstatt ein Kernelpaket zu haben, das aktualisiert wird, wird jedes Mal ein völlig neues Kernelpaket erstellt, und das Kernel-Metapaket wird aktualisiert, um von dem neuen Kernelpaket anstelle des alten abzuhängen. Dies wurde gemacht, damit Sie die alten Kernelversionen behalten können, so dass Sie, falls ein Problem beim Booten des neuen Kernels auftritt, den alten aus dem Bootmenü auswählen und wiederherstellen können.

Kommentare (1)