Co to jest „dist-upgrade” i dlaczego uaktualnia więcej niż „upgrade”?

395

Zastanawiałem się, dlaczego upgradeczasami nie chce aktualizować niektórych części systemu, a dist-upgraderobi to. Oto przykład po uruchomieniu 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.

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

Innymi słowy, dlaczego nie może tego wykonać upgrade?

Richard Rodriguez
źródło

Odpowiedzi:

327

Z apt-getinstrukcji :

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.

A dzięki nowszemu aptnarzędziu dostępnemu od 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.

W danym przypadku, widzę, na przykład, że linux-headersjest to pakiet wirtualny, który jest dostarczany przez oba linux-headers-3.0.0-12a linux-headers-3.0.0-13i to brzmi jak rodzaj instalacji i usuwania pakietu obsługiwane przez dist-upgrade, ale nie upgrade.

jcollado
źródło
4
Nie widzę full-upgradeopcji jako apt-getponiżej 14.04.1.
nobar
Nie wiedziałem o aptżadnym z nich, ale wydaje się, że jest to zupełnie inne polecenie, zgodnie z linkiem do strony
podręcznika
18
@nobar Nie widzisz, ponieważ jest to opcja apti nie apt-get... :-) Spróbuj man apt.
Hastur
Dobra, szukałem i najwcześniejszy link, jaki znalazłem, dotyczy Ubuntu 15.10 (który wyszedł pod koniec 2014 roku, co wydaje się rozsądne w testowaniu Jessie) manpages.ubuntu.com/manpages/wily/en/man8/apt.8.html
Z bozonem
6
@Zboson Tak, a 14.04 wyszło nie w 2011 roku, ale w kwietniu 2014 ... widzisz wzór?
tgies
137

apt-get upgradejest ograniczony do przypadku, gdy pakiety mają zostać zastąpione nowszymi wersjami, ale żaden pakiet nie musi być dodawany ani usuwany. Na przykład nowa wersja przeglądarki Firefox powinna zostać zainstalowana apt-get upgrade.

Jednak apt-get upgradeodmówi działania, gdy zaktualizowane wersje wymagają dodania lub usunięcia. Na przykład, gdy masz linux-image-3.2.0-10-genericzainstalowane jądro i linux-image-3.2.0-11-genericpojawia się, linux-image-genericpakiet jest aktualizowany w zależności od nowszej wersji. Aby zainstalować nowe jądro, musisz uruchomić apt-get dist-upgrade.

Zauważ, że an apt-get upgradepowie, że pakiety jądra zostały held back. To jest wskazówka do używania apt-get dist-upgrade.

pablomme
źródło
2
Doskonały! : D Dwa kolejne pytania ... z czego korzysta graficzny menedżer aktualizacji w Ubuntu? Jaki jest zalecany?
THpubs
11
Narzędzie graficzne update-manager, nie używa apt-getbezpośrednio; zamiast tego działa z backendem o nazwie aptdaemon. Standardowe możliwości programu update-managerto połączenie trybów upgradei : można dodawać, ale nie usuwać pakietów - wywołuje narzędzie „Częściowe uaktualnienie”, gdy wymagane jest usunięcie. Korzystając z wiersza polecenia, użyj . Jeśli zobaczysz, że zgłasza, że ​​pakiety zostały „wstrzymane”, uruchom, aby odebrać pozostałe aktualizacje. dist-upgradeapt-getapt-get upgradeapt-get dist-upgrade
pablomme
33

Zasadniczo aktualizacja spowoduje aktualizację tylko istniejących pakietów z jednej wersji do drugiej. Nie instaluje ani nie usuwa pakietów, nawet jeśli jest to wymagane do aktualizacji innych. W przypadku aktualizacji jądra, aktualizacja pakietu linux-generic wymaga zainstalowania nowego pakietu linux-3.0.0-13-generic, a ponieważ upgrade odmawia instalacji lub usunięcia pakietów, odmawia aktualizacji linux-generic.

Czasami różne niezgodności między pakietami będą wymagać usunięcia niektórych pakietów w celu uaktualnienia innych, a to również będzie wymagać aktualizacji dist. Aktualizacje jądra zawsze wymagają aktualizacji dist ze względu na sposób ich obsługi. Zamiast aktualizować pakiet jądra, za każdym razem tworzony jest zupełnie nowy pakiet jądra, a metapakiet jądra jest aktualizowany w zależności od nowego pakietu jądra zamiast starego. Zostało to zrobione, aby zachować stare wersje jądra, aby w przypadku problemów z uruchomieniem nowego jądra można wybrać starą z menu rozruchu i odzyskać.

psusi
źródło
2
Najlepsza treść. Wciąż, jak zachować określoną paczkę?
0xC0000022L,
11

apt-get upgradeKomenda normalnie tylko zainstalować aktualizacje (lub poprawki) do aktualnie zainstalowanych pakietów. Zwykle za pomocą tego polecenia instalowana jest na przykład nowa wersja Mozilla Firefox .

Jednak apt-get upgradebędą NIE ogólnie instalować nowe wersje, w których wymagane jest w tym (usuwanie pakietów lub aktualizację grub) istotne zmiany. Na przykład, gdy nowe jądro Linuksa (linux-image-3.xx-xx-generic itp.) Jest dostępne, pakiet nie zostanie zainstalowany.

Aby zainstalować nowe jądro, musisz uruchomić apt-get dist-upgrade. Zostaniesz powiadomiony po uruchomieniu apt-get upgrade, ponieważ będzie to oznaczać, że niektóre pakiety zostały wstrzymane. To twoja cue używać: apt-get dist-upgrade.

david6
źródło
12
To jest mylące. dist-upgradenie zaktualizuje się do nowej wersji, chyba sources.listże zostanie odpowiednio zmodyfikowany (i nawet wtedy nie jest to obsługiwany sposób aktualizacji w Ubuntu). Kiedy instalowane jest nowe jądro dist-upgrade, nie jest to nowa wersja Ubuntu . To tylko nowy pakiet. Ponadto twierdzenie „lub wymagana jest aktualizacja GRUB” jest fałszywe. sudo apt-get upgradedoskonale nadaje się do aktualizacji pakietów w sytuacji, gdy GRUB musi zostać zaktualizowany, o ile nie zostaną usunięte żadne pakiety, a nowe pakiety zostaną zainstalowane. update-grubjest uruchamiany automatycznie, jak zawsze.
Eliah Kagan
2
Powinieneś napisać własną odpowiedź, ponieważ nie dodaje to mojej jasności.
david6
2
Poza tym, o czym wspomniał Eliah, istotną kwestią jest to, że apt-get upgradenie usunie ani nie doda pakietów. Jeśli poprawka do pakietu wymaga nowego pakietu, aktualizacja zostanie wstrzymana. Odpowiedź pablomme , którą zrewidowałeś, by była mniej dokładna, jest lepsza i radziłbym czytelnikom, aby do niej poszli.
Chan-Ho Suh
1
Korekta: apt-get upgradenigdy nie instaluje ani nie usuwa żadnych pakietów. Uaktualnienia jądra są pakowane jako nowe pakiety, w wyniku czego apt-get upgradenigdy nie uaktualnią jądra. Fakt, że aktualizacja jądra wprowadza „poważne” zmiany, takie jak konfiguracja GRUB, nie jest przyczyną różnicy między upgradei dist-upgrade.
Mikko Rantalainen,
1

Twoja najlepsza opcja to:

apt full-upgrade

- który automatycznie obsługuje zależności podczas aktualizacji pakietów; natomiast:

apt upgrade

-nie NALEŻY automatycznie obsługiwać zależności podczas aktualizacji pakietów.

- duBtrotterS

Brett Maddox-Stroud
źródło