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?
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.
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
.
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.