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


395

Mi chiedevo perché a upgradevolte non volessi aggiornare determinate parti del sistema, mentre lo dist-upgradefa. Ecco un esempio dopo l'esecuzione 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?

Risposte:


328

Dal apt-getmanuale :

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 nuovo aptstrumento disponibile dal 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 vostro caso particolare, non vedo, per esempio, che linux-headersè un pacchetto virtuale fornito da entrambi linux-headers-3.0.0-12e linux-headers-3.0.0-13e che suona come il tipo di installazione del pacchetto e la rimozione gestito da dist-upgrade, ma non da upgrade.


4
Non vedo full-upgradecome un'opzione per il apt-get14.04.1.
nobar,

apt
Neanche

18
@nobar Non vedi perché è un'opzione apte non di apt-get... :-) Prova man apt.
Hastur,

Va bene, ho cercato e il primo link che ho trovato è per Ubuntu 15.10 (che è uscito alla fine del 2014, che sembra ragionevole con i test di Jessie) manpages.ubuntu.com/manpages/wily/en/man8/apt.8.html
Z boson

6
@Zboson Sì, e il 14.04 è uscito non nel 2011, ma nell'aprile 2014 ... vedi lo schema?
tgies,

137

apt-get upgradeè limitato al caso in cui i pacchetti devono essere sostituiti da versioni più recenti, ma non è necessario aggiungere o rimuovere pacchetti. Una nuova versione di Firefox, ad esempio, dovrebbe essere installabile con apt-get upgrade.

Tuttavia, apt-get upgradesi rifiuterà di funzionare quando ci sono aggiunte o rimozioni richieste dalle versioni aggiornate. Ad esempio, quando il kernel è linux-image-3.2.0-10-genericinstallato e linux-image-3.2.0-11-genericappare, il linux-image-genericpacchetto viene aggiornato in base alla versione più recente. Per installare il nuovo kernel, è necessario eseguire apt-get dist-upgrade.

Notate come apt-get upgradedirà che i pacchetti del kernel sono stati held back. Questo è il suggerimento per l'utilizzo apt-get dist-upgrade.


2
Perfetto! : D Altre due domande ... cosa viene utilizzato dal gestore degli aggiornamenti grafici in Ubuntu? Qual è quello raccomandato?
THpubs il

11
L'utilità grafica, update-managernon utilizza apt-getdirettamente; invece funziona con un backend chiamato aptdaemon. Le abilità standard di update-managersono un mix delle modalità upgradee dist-upgradedi apt-get: può aggiungere ma non rimuovere pacchetti - invoca lo strumento "Aggiornamento parziale" quando sono necessarie le rimozioni. Quando si utilizza la riga di comando, utilizzare apt-get upgrade. Se vedi che segnala che i pacchetti sono stati "trattenuti", esegui apt-get dist-upgradeper raccogliere gli aggiornamenti rimanenti.
pablomme,

33

Fondamentalmente l'aggiornamento aggiornerà solo i pacchetti esistenti da una versione all'altra. Non installerà o rimuoverà i pacchetti, anche se è necessario farlo per aggiornare gli altri. Nel caso degli aggiornamenti del kernel, l'aggiornamento del pacchetto linux-generico richiede l'installazione del nuovo pacchetto linux-3.0.0-13-generico e, poiché l'aggiornamento rifiuta di installare o rimuovere i pacchetti, si rifiuta di aggiornare linux-generico.

A volte varie incompatibilità tra i pacchetti richiederanno la rimozione di alcuni pacchetti per aggiornarne altri e ciò richiederà anche dist-upgrade. Gli aggiornamenti del kernel richiedono sempre dist-upgrade a causa del modo in cui vengono 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 in modo da dipendere dal nuovo pacchetto del kernel anziché dal vecchio. Questo è stato fatto in modo da mantenere le vecchie versioni del kernel in modo che, nel caso ci fosse un problema con l'avvio del nuovo kernel, è possibile scegliere quella vecchia dal menu di avvio e ripristinare.


2
Il migliore. Tuttavia, come mantenere un determinato pacchetto?
0xC0000022L

11

Il apt-get upgradecomando normalmente installa solo gli aggiornamenti (o le correzioni) ai pacchetti attualmente installati. In genere una nuova versione di Mozilla Firefox , ad esempio, verrebbe installata con questo comando.

Tuttavia apt-get upgradesarà NON generalmente installare nuove uscite, in cui (è richiesto, tra cui la rimozione dei colli o aggiornamento GRUB) grandi cambiamenti. Ad esempio, quando è disponibile un nuovo kernel Linux (linux-image-3.xx-xx-generic, ecc.), Il pacchetto non verrà installato.

Per installare il nuovo kernel, è necessario eseguire apt-get dist-upgrade. Riceverai una notifica durante l'esecuzione apt-get upgrade, poiché dirà che alcuni pacchetti sono stati trattenuti. Questo è il tuo spunto da utilizzare: apt-get dist-upgrade.


12
Questo è fuorviante. dist-upgradenon verrà aggiornato a una nuova versione a meno che non sources.listsia stato modificato di conseguenza (e anche in questo caso, non è un modo supportato per eseguire l'aggiornamento in Ubuntu). Quando viene installato un nuovo kernel con dist-upgrade, questa non è una nuova versione di Ubuntu . È solo un nuovo pacchetto. Inoltre, l'affermazione "è necessario l'aggiornamento di GRUB" è falsa. sudo apt-get upgradeè perfettamente in grado di aggiornare i pacchetti in una situazione in cui GRUB deve essere aggiornato, purché non vengano rimossi pacchetti e installati nuovi pacchetti. update-grubviene eseguito automaticamente, come sempre.
Eliah Kagan,

2
Dovresti scrivere la tua risposta, in quanto ciò non aggiunge chiarezza alla mia.
david6

2
Oltre a ciò che ha detto Eliah, il punto essenziale è che apt-get upgradenon rimuoverà o aggiungerà pacchetti. Se una correzione per un pacchetto richiede un nuovo pacchetto, l'aggiornamento verrà trattenuto. La risposta di Pablomme , che hai rivisto per essere meno accurata, è migliore e consiglierei ai lettori di andare su quella.
Chan-Ho Suh,

1
Correzione: apt-get upgradenon installerà o rimuoverà mai alcun pacchetto. Gli aggiornamenti del kernel sono impacchettati come nuovi pacchetti e, di conseguenza, apt-get upgradenon aggiorneranno mai il kernel. Il fatto che l'aggiornamento del kernel apporti cambiamenti "importanti" come la configurazione di GRUB non è la ragione della differenza tra upgradee dist-upgrade.
Mikko Rantalainen,

1

La tua migliore opzione è:

apt full-upgrade

-che gestisce automaticamente le dipendenze durante l'aggiornamento dei pacchetti; mentre:

apt upgrade

-non gestisce automaticamente le dipendenze durante l'aggiornamento dei pacchetti.

- duBtrotterS

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.