Qu'est-ce que «dist-upgrade» et pourquoi met-il à niveau davantage que «upgrade»?

395

Je me demandais pourquoi upgradeparfois, ne veut pas mettre à niveau certaines parties du système, alors que dist-upgradesi. 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.

par rapport à 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 cela ne peut-il pas être réalisé par upgrade?

Richard Rodriguez
la source

Réponses:

328

De apt-getmanuel :

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 aptoutil 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, je vois, par exemple, linux-headersest un paquet virtuel qui est fourni par les deux linux-headers-3.0.0-12et linux-headers-3.0.0-13et qui sonne comme le type d'installation et l' enlèvement paquet manipulé par dist-upgrade, mais non par upgrade.

jcollado
la source
4
Je ne vois pas full-upgradecomme une option à apt-getmoins de 14.04.1.
Novembre
Je ne savais rien aptnon plus, mais il semble que ce soit une commande complètement différente selon la page de manuel qu'il a liée
BlueWizard
18
@nobar Vous ne voyez pas parce que c'est une option de aptet non de apt-get... :-) Essayez man apt.
Hastur
D' accord, je cherchai et le lien plus tôt que j'ai trouvé est pour Ubuntu 15.10 (qui est sorti fin 2014 qui coud raisonnable avec le test Jessie) manpages.ubuntu.com/manpages/wily/en/man8/apt.8.html
boson Z
6
@Zboson Ouais, et 14.04 est sorti pas en 2011, mais en avril 2014 ... voir le modèle?
Tgies
137

apt-get upgradeest limité au cas où des packages doivent être remplacés par des versions plus récentes, mais aucun package ne doit être ajouté ou supprimé. Une nouvelle version de Firefox, par exemple, devrait pouvoir être installée avec apt-get upgrade.

Toutefois, apt-get upgradeil refusera de travailler lorsque des ajouts ou des suppressions sont nécessaires en raison des versions mises à jour. Par exemple, lorsque le noyau est linux-image-3.2.0-10-genericinstallé et linux-image-3.2.0-11-genericapparaît, la linux-image-genericmise à jour du package dépend de la version la plus récente. Pour installer le nouveau noyau, vous devez exécuter apt-get dist-upgrade.

Remarquez comment on apt-get upgradeva dire que les paquets du noyau ont été held back. C'est la queue pour utiliser apt-get dist-upgrade.

pablomme
la source
2
Parfait! : D Deux autres questions ... Qu'est-ce qui est utilisé par le gestionnaire de mise à jour graphique dans Ubuntu? Quel est le recommandé?
THpubs
11
L'utilitaire graphique update-manager, n'utilise pas apt-getdirectement; Au lieu de cela, cela fonctionne avec un backend appelé aptdaemon. Les capacités standard de update-managersont un mélange des modes upgradeet dist-upgradede apt-get: il peut ajouter des packages, mais pas les supprimer. Il appelle l'outil "Mise à niveau partielle" lorsque des suppressions sont nécessaires. Lorsque vous utilisez la ligne de commande, utilisez apt-get upgrade. Si vous voyez des rapports indiquant que des packages ont été "retenus", exécutez-les apt-get dist-upgradepour récupérer les mises à jour restantes.
Pablomme
33

Fondamentalement, la mise à niveau ne mettra à niveau que les packages existants d'une version à une autre. Il n’installe ni ne supprime les packages, même si cela est nécessaire pour mettre à niveau les autres. 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 la mise à niveau refuse d'installer ou de supprimer des packages, elle refuse de mettre à niveau linux-generic.

Parfois, diverses incompatibilités entre les packages nécessiteront la suppression de certains packages pour en mettre à jour d'autres, ce qui nécessitera également la mise à niveau dist. Les mises à jour du noyau nécessitent toujours dist-upgrade en raison de la manière dont elles sont gérées. Plutôt que d'avoir un package de noyau mis à jour, un package de noyau entièrement nouveau est créé à chaque fois et le méta-paquet de noyau est mis à jour pour dépendre du nouveau package de noyau au lieu de l'ancien. Ceci a été fait pour que vous gardiez les anciennes versions du noyau et qu'en cas de problème avec le démarrage du nouveau noyau, vous puissiez choisir l'ancienne dans le menu de démarrage et la récupérer.

psusi
la source
2
Meilleur Gist. Pourtant, comment garder un certain paquet?
0xC0000022L
11

La apt-get upgradecommande installera normalement uniquement les mises à jour (ou correctifs) des packages actuellement installés. Par exemple, une nouvelle version de Mozilla Firefox , par exemple, serait installée avec cette commande.

Cependant, apt-get upgradeil n’installe généralement PAS les nouvelles versions nécessitant des modifications majeures (y compris la suppression de packages ou la mise à jour GRUB). Par exemple, lorsqu'un nouveau noyau Linux (linux-image-3.xx-xx-generic, etc.) est disponible, le package ne sera pas installé.

Pour installer le nouveau noyau, vous devrez exécuter apt-get dist-upgrade. Vous serez averti lorsque vous exécuterez apt-get upgrade, car il sera dit que certains paquets ont été retenus. C'est votre queue de billard à utiliser: apt-get dist-upgrade.

david6
la source
12
Ceci est trompeur. dist-upgradeLa mise à niveau vers une nouvelle version ne sera mise à niveau que si elle sources.lista été modifiée en conséquence (et même dans ce cas, ce n'est pas un moyen de mise à niveau pris en charge dans Ubuntu). Lorsqu'un nouveau noyau est installé avec dist-upgrade, ce n'est pas une nouvelle version d'Ubuntu . C'est juste un nouveau paquet. De plus, la déclaration "ou la mise à jour GRUB est requise" est fausse. sudo apt-get upgradeest parfaitement capable de mettre à jour des paquets dans une situation où GRUB doit être mis à jour, à condition qu'aucun paquet ne soit supprimé et que de nouveaux paquets ne soient installés. update-grubest exécuté automatiquement, comme toujours.
Eliah Kagan
2
Vous devriez écrire votre propre réponse, car cela n’ajoute aucune clarté à la mienne.
david6
2
Outre ce qu'Eliah a mentionné, le point essentiel est que apt-get upgradecela ne supprime ni n'ajoute de paquet. Si un correctif sur un paquet nécessite un nouveau paquet, la mise à jour sera retenue. La réponse de pablomme , que vous avez révisée pour être moins précise, est meilleure et je conseillerais aux lecteurs d'y aller.
Chan-Ho Suh
1
Correction: n'installera ou ne supprimeraapt-get upgrade jamais aucun paquet. Les mises à niveau du noyau sont regroupées dans de nouveaux packages et, par conséquent, ne le met jamais à niveau. Le fait que la mise à niveau du noyau entraîne des modifications "majeures" telles que la configuration de GRUB n'est pas la raison de la différence entre et . apt-get upgradeupgradedist-upgrade
Mikko Rantalainen le
1

Votre meilleure option est:

apt full-upgrade

-qui gère automatiquement les dépendances lors de la mise à niveau des paquets; tandis que:

apt upgrade

-Ne gère PAS automatiquement les dépendances lors de la mise à niveau des packages.

- duBtrotterS

Brett Maddox-Stroud
la source