I usually use apt-get update && apt-get upgrade
to run my updates and upgrades instead of the GUI because it seems to run more quickly.
However, I've noticed lately that I often get a message that one of my upgrades was held back. I then usually run dist-upgrade
to run it through and it works fine. As far as I can tell after reading this question and its answers, dist-upgrade
does all the same things and then some.
So, my question is: Why use apt-get upgrade
at all? Why not use apt-get dist-upgrade
all the time? Why does apt-get upgrade
even exist?
I typically upgrade my machines with:
Below is an excerpt from
man apt-get
. Using upgrade keeps to the rule: under no circumstances are currently installed packages removed, or packages not already installed retrieved and installed. If that's important to you, useapt-get upgrade
. If you want things to "just work", you probably wantapt-get dist-upgrade
to ensure dependencies are resolved.To expand on why you'd want upgrade instead of dist-upgrade, if you are a systems administrator, you need predictability. You might be using advanced features like apt pinning or pulling from a collection of PPAs (perhaps you have an in-house PPA), with various automations in place to inspect your system and available upgrades instead of always eagerly upgrading all available packages. You would get very frustrated when apt performs unscripted behavior, particularly if this leads to downtime of a production service.
I know this question has been answered and is a year old, but I feel this needs to be said. Ubuntu 14.04 and later (and Debian Jessie and later, for those finding this from Google) uses APT 1.0, which allows the command
apt
instead ofapt-get
andapt-cache
for some operations.apt-get upgrade
will not change what is installed (only versions),apt-get dist-upgrade
will install or remove packages as necessary to complete the upgrade,apt upgrade
will automatically install but not remove packages.apt full-upgrade
performs the same function asapt-get dist-upgrade
.The
upgrade
option only installs new version of the packages that are already installed on the system (and yes, kernel updates belong to them).However, sometimes the updates change dependencies: for example, a new version of a package will no longer depend on a library that you have installed, or will require installation of additional libraries. The
upgrade
option will never remove installed packages that you no longer actually need.However, the
dist-upgrade
option can "intelligently" handle changes in the dependencies system. This includes removing packages that are no longer necessary or resolve conflicts between packages that arose because of changes in the dependencies.Users might have come to rely on packages that were installed implicitly because of other (explicitly installed) packages' dependency on them. Thus the packaging system cannot be aware of a user/administrator desire to retain certain functionality that might otherwise be removed via dist-upgrade.