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

395

Ich habe mich gefragt, warum upgrademanchmal bestimmte Teile des Systems nicht aktualisiert werden sollen, obwohl dies der dist-upgradeFall ist. Hier ist ein Beispiel nach dem Ausführen 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 von durchgeführt werden upgrade?

Richard Rodriguez
quelle

Antworten:

327

Aus dem apt-getHandbuch :

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 aptTool ab 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.

In Ihrem speziellen Fall ist dies beispielsweise linux-headersein virtuelles Paket, das sowohl von als auch bereitgestellt wird linux-headers-3.0.0-12und sich linux-headers-3.0.0-13nach der Art der Paketinstallation und -entfernung anhört, die von dist-upgrade, aber nicht von ausgeführt wird upgrade.

jcollado
quelle
4
Ich sehe keine full-upgradeOption apt-getunter 14.04.1.
Am
Ich wusste auch nichts darüber, aptaber es scheint ein völlig anderer Befehl zu sein, laut der Manpage, die er verlinkt hat
BlueWizard 20.10.15
18
@nobar Du siehst nicht, weil es eine Option von aptund nicht von apt-get... ist :-) Versuch man apt.
Hastur
Okay, ich habe gesucht und der früheste Link, den ich gefunden habe, ist für Ubuntu 15.10 (der Ende 2014 herauskam und mit Jessie-Tests in Ordnung war
Z boson
6
@ Zboson Yeah, und 14.04 kamen nicht im Jahr 2011, sondern im April 2014 heraus ... siehst du das Muster?
tgies
137

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

Funktioniert jedoch apt-get upgradenicht, wenn in den aktualisierten Versionen Ergänzungen oder Entfernungen erforderlich sind. Wenn Sie beispielsweise den Kernel linux-image-3.2.0-10-genericinstalliert haben und linux-image-3.2.0-11-genericangezeigt werden, wird das linux-image-genericPaket so aktualisiert, dass es von der neueren Version abhängt. Um den neuen Kernel zu installieren, müssen Sie ausführen apt-get dist-upgrade.

Beachten Sie, wie ein apt-get upgradeWille sagt, dass die Kernelpakete gewesen sind held back. Das ist das Stichwort für die Verwendung apt-get dist-upgrade.

pablomme
quelle
2
Perfekt! : D Noch zwei Fragen ... Was wird vom grafischen Update-Manager in Ubuntu verwendet? Was ist die empfohlene?
THpubs
11
Das grafische Dienstprogramm update-managerwird nicht apt-getdirekt verwendet. Stattdessen funktioniert es mit einem Backend namens aptdaemon. Die Standardfähigkeiten von update-managersind eine Mischung aus den Modi upgradeund : Es kann Pakete hinzufügen, aber nicht entfernen - es ruft das Tool "Partial Upgrade" auf, wenn Entfernungen erforderlich sind. Verwenden Sie bei Verwendung der Befehlszeile . Wenn Sie feststellen, dass Pakete "zurückgehalten" wurden, führen Sie den Befehl aus, um die verbleibenden Aktualisierungen abzurufen. dist-upgradeapt-getapt-get upgradeapt-get dist-upgrade
Pablomme
33

Grundsätzlich werden bei einem Upgrade nur vorhandene Pakete von einer Version auf eine andere aktualisiert. Es werden keine Pakete installiert oder entfernt, auch wenn dies für ein Upgrade anderer erforderlich ist. Im Falle von Kernel-Updates erfordert das Upgrade des Linux-Generic-Pakets die Installation des neuen Linux-3.0.0-13-Generic-Pakets. Da das Upgrade das Installieren oder Entfernen von Paketen verweigert, lehnt es das Upgrade von Linux-Generic ab.

Manchmal erfordern verschiedene Inkompatibilitäten zwischen Paketen, dass einige Pakete entfernt werden, um andere zu aktualisieren, und dies erfordert auch ein Dist-Upgrade. Kernel-Updates erfordern aufgrund ihrer Handhabung immer ein Dist-Upgrade. Anstatt ein Kernel-Paket zu haben, das aktualisiert wird, wird jedes Mal ein völlig neues Kernel-Paket erstellt, und das Kernel-Metapaket wird aktualisiert, um von dem neuen Kernel-Paket anstelle des alten abzuhängen. Dies wurde gemacht, damit Sie die alten Kernel-Versionen behalten, damit Sie im Falle eines Problems beim Booten des neuen Kernels den alten Kernel aus dem Boot-Menü auswählen und wiederherstellen können.

Psusi
quelle
2
Beste Idee. Dennoch, wie man ein bestimmtes Paket aufbewahrt?
0xC0000022L
11

Der apt-get upgradeBefehl installiert normalerweise nur Updates (oder Fixes) für aktuell installierte Pakete. In der Regel wird mit diesem Befehl beispielsweise eine neue Version von Mozilla Firefox installiert.

Im Allgemeinen apt-get upgradewerden jedoch KEINE neuen Releases installiert, bei denen größere Änderungen (einschließlich Entfernen von Paketen oder GRUB-Update) erforderlich sind. Wenn beispielsweise ein neuer Linux-Kernel (linux-image-3.xx-xx-generic usw.) verfügbar ist, wird das Paket nicht installiert.

Um den neuen Kernel zu installieren, müssen Sie ausführen apt-get dist-upgrade. Sie werden benachrichtigt, wenn Sie ausgeführt werden apt-get upgrade, da darauf hingewiesen wird, dass bestimmte Pakete zurückgehalten wurden. Das ist Ihr Stichwort zu verwenden: apt-get dist-upgrade.

david6
quelle
12
Das ist irreführend. dist-upgradewird nicht auf ein neues Release upgraden, es sei denn, dies sources.listwurde entsprechend geändert (und selbst dann ist dies keine unterstützte Methode zum Upgrade in Ubuntu). Wenn ein neuer Kernel mit installiert dist-upgradewird, ist dies keine neue Version von Ubuntu . Es ist nur ein neues Paket. Darüber hinaus ist die Behauptung "oder GRUB-Update erforderlich" falsch. sudo apt-get upgradeist in der Lage, Pakete in einer Situation zu aktualisieren, in der GRUB aktualisiert werden muss, solange keine Pakete entfernt und neue Pakete installiert werden. update-grubwird wie immer automatisch ausgeführt.
Eliah Kagan
2
Sie sollten Ihre eigene Antwort schreiben, da dies meiner keine Klarheit verleiht.
David6
2
Neben dem, was Eliah erwähnte, ist der wesentliche Punkt, dass apt-get upgradekeine Pakete entfernt oder hinzugefügt werden. Wenn für eine Paketkorrektur ein neues Paket erforderlich ist, wird das Update zurückgehalten. Die Antwort von Pablomme , die Sie als weniger genau überarbeitet haben, ist besser, und ich rate den Lesern, zu dieser Antwort überzugehen .
Chan-Ho Suh
1
Korrektur: Installiert oder entferntapt-get upgrade niemals Pakete. Kernel-Upgrades werden als neue Pakete gepackt und führen daher niemals zu einem Upgrade des Kernels. Die Tatsache, dass das Kernel-Upgrade "größere" Änderungen wie die GRUB-Konfiguration vornimmt, ist nicht der Grund für den Unterschied zwischen und . apt-get upgradeupgradedist-upgrade
Mikko Rantalainen
1

Ihre beste Option ist:

apt full-upgrade

-die automatisch die Abhängigkeiten behandelt, wenn Pakete aktualisiert werden; wohingegen:

apt upgrade

-behandelt Abhängigkeiten beim Upgrade von Paketen NICHT automatisch.

- duBtrotterS

Brett Maddox-Stroud
quelle