Je me demandais pourquoi upgrade
ne veut parfois pas mettre à jour certaines parties du système, alors que dist-upgrade
le fait. Voici un exemple après avoir exécuté `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]?
En d'autres termes, pourquoi cette opération ne peut-elle pas être effectuée par `upgrade
' ?
Extrait du [manuel apt-get
][1] :
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.
Et avec le nouvel outil [apt
][2] disponible à partir de 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.
Dans votre cas particulier, je vois, par exemple, que linux-headers
est un paquet virtuel qui est fourni à la fois par linux-headers-3.0.0-12
et linux-headers-3.0.0-13
et cela ressemble au type d'installation et de suppression de paquet géré par dist-upgrade
, mais pas par upgrade
.
[1] : http://manpages.ubuntu.com/apt-get.8 [2] : http://manpages.ubuntu.com/apt.8
apt-get upgrade
est limité au cas où les paquets doivent être remplacés par des versions plus récentes, mais aucun paquet ne doit être ajouté ou supprimé. Une nouvelle version de Firefox, par exemple, devrait pouvoir être installée avec apt-get upgrade
.
Cependant, apt-get upgrade
refusera de fonctionner s'il y a des ajouts ou des suppressions requis par les versions mises à jour. Par exemple, lorsque vous avez installé le noyau linux-image-3.2.0-10-generic
et que linux-image-3.2.0-11-generic
apparaît, le paquet linux-image-generic
est mis à jour pour dépendre de la nouvelle version. Afin d'installer le nouveau noyau, vous devez exécuter apt-get dist-upgrade
.
Remarquez comment un apt-get dist-upgrade
dira que les paquets du noyau ont été retenus
. C'est le signe qu'il faut utiliser apt-get dist-upgrade
.
En principe, la mise à niveau ne fait que mettre à niveau les paquets existants d'une version à une autre. Il n'installera ni ne supprimera aucun paquet, même si cela est nécessaire pour en mettre d'autres à niveau. Dans le cas des mises à jour du noyau, la mise à niveau du paquet linux-generic nécessite l'installation du nouveau paquet linux-3.0.0-13-generic, et comme upgrade refuse d'installer ou de supprimer des paquets, il refuse de mettre à niveau linux-generic.
Parfois, diverses incompatibilités entre paquets nécessiteront que certains paquets soient supprimés afin de mettre à niveau d'autres paquets, et cela nécessitera également dist-upgrade. Les mises à jour du noyau nécessiteront toujours un dist-upgrade à cause de la façon dont elles sont gérées. Plutôt que d'avoir un paquet du noyau qui est mis à jour, un paquet du noyau entièrement nouveau est créé à chaque fois, et le métapaquet du noyau est mis à jour pour dépendre du nouveau paquet du noyau au lieu de l'ancien. Cela permet de conserver les anciennes versions du noyau et, en cas de problème lors du démarrage du nouveau noyau, de choisir l'ancien dans le menu de démarrage et de récupérer.