apt-get
is the first front end — command-line based — which was developed within the project. apt
is a second command-line based front end provided by APT which overcomes some design mistakes of apt-get
.
apt
has been improved for interactive use and to actually do what most users expect. The APT developers reserve the right to change the public interface of this tool to further improve it. Conversely, the public interface of apt-get
is well defined and will not change in any backwards incompatible way. It is thus the tool that you want to use when you need to script package installation requests.
synaptic
, aptitude
(which includes both a text mode interface and a graphical one — even if not complete yet), wajig
, etc. The most recommended interface, apt
, is the one that we will use in the examples given in this section. Note, however, that apt-get
and aptitude
have a very similar command line syntax. When there are major differences between these three commands, these will be detailed.
apt update
. Depending on the speed of your connection and configuration, the operation can take a while, since it involves downloading a certain number of (usually compressed) files (Packages
, Sources
, Translation-language-code
), which have gradually become bigger and bigger as Debian has developed (at least 10-16 MB of data for the main
section). Of course, installing from a CD-ROM/DVD set does not require any downloading — in this case, the operation is very fast.
apt install package
and apt remove package
. In both cases, APT will automatically install the necessary dependencies or delete the packages which depend on the package that is being removed. The apt purge package
command involves a complete uninstallation by deleting the configuration files as well.
sources.list
mentions several distributions, it is possible to give the version of the package to install. A specific version number can be requested with apt install package=version
, but indicating its distribution of origin (Stable, Testing or Unstable) — with apt install package/distribution
— is usually preferred. With this command, it is possible to go back to an older version of a package (if, for instance, you know that it works well), provided that it is still available in one of the sources referenced by the sources.list
file. Otherwise the snapshot.debian.org
archive can come to the rescue (see sidebar GOING FURTHER Old package versions: snapshot.debian.org
and archive.debian.org
).
Example 6.4. Installation of the Unstable version of spamassassin
#
apt install spamassassin/unstable
.deb
file without any associated package repository, it is still possible to use APT to install it together with its dependencies (provided that the dependencies are available in the configured repositories) with a simple command: apt install ./path-to-the-package.deb
. The leading ./
is important to make it clear that we are referring to a filename and not to the name of a package available in one of the repositories.
apt upgrade
, apt-get upgrade
or aptitude safe-upgrade
(of course after apt update
). This command looks for installed packages which can be upgraded without removing any packages. In other words, the goal is to ensure the least intrusive upgrade possible. apt-get
is slightly more demanding than aptitude
or apt
because it will refuse to install packages which were not installed beforehand.
apt
will generally select the most recent version number (except for packages from Experimental and stable-backports, which are ignored by default whatever their version number). If you specified Testing or Unstable in your sources.list
, apt upgrade
will switch most of your Stable system to Testing or Unstable, which might not be what you intended.
apt
to use a specific distribution when searching for upgraded packages, you need to use the -t
or --target-release
option, followed by the name of the distribution you want (for example, apt -t stable upgrade
). To avoid specifying this option every time you use apt
, you can add APT::Default-Release "stable";
in the file /etc/apt/apt.conf.d/local
.
apt full-upgrade
. With this instruction, apt
will complete the upgrade even if it has to remove some obsolete packages or install new dependencies. This is also the command used by users who work daily with the Debian Unstable release and follow its evolution day by day. It is so simple that it hardly needs explanation: APT's reputation is based on this great functionality.
apt
and aptitude
, apt-get
doesn't know the full-upgrade
command. Instead, you should use apt-get dist-upgrade
(”distribution upgrade”), the historical and well-known command that apt
and aptitude
also accept for the convenience of users who got used to it.
/var/log/apt/history.log
and /var/log/apt/term.log
, whereas dpkg
keeps its log in a file called /var/log/dpkg.log
.
/etc/apt/apt.conf.d/
directory or /etc/apt/apt.conf
itself. Remember, for instance, that it is possible for APT to tell dpkg
to ignore file conflict errors by specifying DPkg::options { "--force-overwrite"; }
.
Acquire::http::proxy "http://yourproxy:3128"
. For an FTP proxy, write Acquire::ftp::proxy "ftp://yourproxy"
. To discover more configuration options, read the apt.conf(5) manual page (for details on manual pages, see Section 7.1.1, “Manual Pages”).
-t
command-line option or the APT::Default-Release
configuration directive).
/etc/apt/preferences.d/
or the /etc/apt/preferences
file with the names of the affected packages, their version, their origin and their new priority.
/etc/apt/preferences
and /etc/apt/preferences.d/
, it first takes into account the most specific entries (often those specifying the concerned package), then the more generic ones (including, for example, all the packages of a distribution). If several generic entries exist, the first match is used. The available selection criteria include the package's name and the source providing it. Every package source is identified by the information contained in a Release
file that APT downloads together with the Packages
files. It specifies the origin (usually “Debian” for the packages of official mirrors, but it can also be a person's or an organization's name for third-party repositories). It also gives the name of the distribution (usually Stable, Testing, Unstable or Experimental for the standard distributions provided by Debian) together with its version (for example, 11 for Debian Bullseye). Let's have a look at its syntax through some realistic case studies of this mechanism.
/etc/apt/preferences
file:
Package: * Pin: release a=stable Pin-Priority: 900 Package: * Pin: release o=Debian Pin-Priority: -10
a=stable
defines the name of the selected distribution. o=Debian
limits the scope to packages whose origin is “Debian”.
Package: perl Pin: version 5.28* Pin-Priority: 1001
apt-cache policy
to display the default priority associated with each package source, or apt-cache policy package
to display the default priority for each available version and source of a package as explained in Section 6.3.1, “The apt-cache policy
Command”.
/etc/apt/preferences
and /etc/apt/preferences.d/
is available in the manual page apt_preferences(5), which you can display with man apt_preferences
.
apt
being such a marvelous tool, it is tempting to pick packages coming from other distributions. For example, after having installed a Stable system, you might want to try out a software package available in Testing or Unstable without diverging too much from the system's initial state.
apt
manages such coexistence very well and limits risks very effectively. The best way to proceed is to list all distributions used in /etc/apt/sources.list
(some people always put the three distributions, but remember that Unstable is reserved for experienced users) and to define your reference distribution with the APT::Default-Release
parameter (see Section 6.2.3, “System Upgrade”).
sources.list
file. In this case, you can use apt install package/testing
to install a package from Testing. If the installation fails due to some unsatisfiable dependencies, let it solve those dependencies within Testing by adding the -t testing
parameter. The same obviously applies to Unstable.
upgrade
and full-upgrade
) are done within Stable except for packages already upgraded to another distribution: those will follow updates available in the other distributions. We will explain this behavior with the help of the default priorities set by APT below. Do not hesitate to use apt-cache policy
(Section 6.3.1, “The apt-cache policy
Command”) to verify the given priorities.
/etc/apt/preferences
has not been used to force priorities higher than 1000 for some packages).
/etc/apt/preferences
to this effect:
Package: * Pin: release a=unstable Pin-Priority: 490
apt
is the tracking of packages installed only through dependencies. These packages are called “automatic”, and often include libraries.
apt-get autoremove
or apt autoremove
will get rid of those packages. aptitude
does not have this command because it removes them automatically as soon as they are identified. In all cases, the tools display a clear message listing the affected packages.
apt-mark auto package
will mark the given package as automatic whereas apt-mark manual package
does the opposite. aptitude markauto
and aptitude unmarkauto
work in the same way although they offer more features for marking many packages at once (see Section 6.5.1, “aptitude
”). The console-based interactive interface of aptitude
also makes it easy to review the “automatic flag” on many packages.
aptitude why package
(apt
and apt-get
have no similar feature):
$
aptitude why python3-debian
i aptitude Suggests apt-xapian-index p apt-xapian-index Depends python3-debian (>= 0.1.14)
aptitude
, synaptic
”), but now APT can also make use of them.
apt list ?automatic
to list all the packages automatically installed. To find packages automatically installed no longer depended upon by manually installed packages the pattern ?garbage
can be used.
?and(PATTERN, PATTERN)
. See apt-patterns(7) and glob(7) for all the patterns you can use and the complex expressions you can create with them.