Cos'è "dist-upgrade" e perché aggiorna più di "upgrade"?

Mi stavo chiedendo perché upgrade a volte non vuole aggiornare alcune parti del sistema, mentre dist-upgrade lo fa. Ecco un esempio dopo l'esecuzione di 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.

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

In altre parole, perché questo non può essere eseguito da upgrade?

Soluzione

Da manuale di apt-get:

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.

E con il più recente strumento apt disponibile dalla 14.04 in poi:

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.

Nel tuo caso particolare, vedo, per esempio, che linux-headers è un pacchetto virtuale che è fornito sia da linux-headers-3.0.0-12 che da linux-headers-3.0.0-13 e questo suona come il tipo di installazione e rimozione di pacchetti gestito da dist-upgrade, ma non da upgrade.

Commentari (7)

apt-get upgrade è limitato al caso in cui i pacchetti devono essere sostituiti da versioni più recenti, ma nessun pacchetto deve essere aggiunto o rimosso. Una nuova versione di Firefox, per esempio, dovrebbe essere installabile con apt-get upgrade.

Tuttavia apt-get upgrade si rifiuterà di funzionare quando ci sono aggiunte o rimozioni richieste dalle versioni aggiornate. Per esempio, quando hai installato il kernel linux-image-3.2.0-10-generic e appare linux-image-3.2.0-11-generic, il pacchetto linux-image-generic viene aggiornato per dipendere dalla nuova versione. Per installare il nuovo kernel, è necessario eseguire apt-get dist-upgrade.

Notate come un apt-get upgrade dirà che i pacchetti del kernel sono stati ritenuti indietro. Questo è lo spunto per usare apt-get dist-upgrade.

Commentari (2)

Fondamentalmente upgrade aggiornerà solo i pacchetti esistenti da una versione all'altra. Non installerà o rimuoverà pacchetti, anche se ciò è richiesto per aggiornare altri. Nel caso degli aggiornamenti del kernel, aggiornare il pacchetto linux-generic richiede l'installazione del nuovo pacchetto linux-3.0.0-13-generic, e poiché upgrade rifiuta di installare o rimuovere pacchetti, rifiuta di aggiornare linux-generic.

A volte varie incompatibilità tra i pacchetti richiederanno la rimozione di alcuni pacchetti per poterne aggiornare altri, e anche questo richiederà dist-upgrade. Gli aggiornamenti del kernel richiederanno sempre il dist-upgrade a causa di come sono gestiti. Invece di avere un pacchetto del kernel che viene aggiornato, ogni volta viene creato un pacchetto del kernel completamente nuovo e il metapacchetto del kernel viene aggiornato per dipendere dal nuovo pacchetto del kernel invece che dal vecchio. Questo è stato fatto in modo da tenere in giro le vecchie versioni del kernel in modo che, nel caso ci sia un problema con l'avvio del nuovo kernel, si possa scegliere quello vecchio dal menu di avvio e recuperare.

Commentari (1)