Advanced Packaging Tool

From Wikipedia, the free encyclopedia

Advanced Packaging Tool
Latest release 0.6.46.4-0.1[1]
Preview release 0.7.13[2]
Written in C
OS Cross-platform
Platform Debian and its derivatives
Genre Package management system
License GNU General Public License
Website [1]

The Advanced packaging tool, or APT, is a user interface that works with core libraries to handle the sometimes difficult process of installing software on Linux.[3] APT simplifies the process of managing software on Unix-like computer systems by automating the retrieval, configuration and installation of software packages, either from binary files or by compiling source code.[3] The Fink project has ported APT to Mac OS X for some of its own package management tasks, and APT is also available in OpenSolaris (included in Nexenta OS distribution).[4]

Distributed under the GNU General Public License, APT is free software.

Contents

[edit] Usage

There is no single "apt" program; APT is a C++ library of functions (known as libapt) which are used by front-end programs for dealing with packages, such as apt-get and apt-cache. They are commonly used in examples due to their simplicity and ubiquity; apt-get and apt-cache are of "important" priority in all current Debian releases, and are therefore installed in a default Debian installation.

Several other front-ends to APT exist, which provide more advanced installation functions and more intuitive interfaces. These include:

APT front-ends can:

  • search for new packages;
  • upgrade packages;
  • install or remove packages;
  • upgrade the whole system to a new release.

APT front-ends can list the dependencies of packages being installed or upgraded, ask the administrator if packages recommended or suggested by newly installed packages should be installed too, automatically install dependencies and perform other operations on the system such as removing obsolete files and packages.

APT is often hailed as one of Debian's best features.[6]

A major feature in APT is the way it calls dpkg - it does topological sorting of the list of packages to be installed or removed and calls dpkg in the best possible sequence. In some cases it utilizes the --force options in dpkg. However, it only does this when it is unable to calculate how to avoid the reason dpkg requires the action to be forced.

Other than install, the other most used apt-get commands are apt-get update, apt-get upgrade and apt-get dist-upgrade.

[edit] Install

Install is followed by one or more packages desired for installation. Each package is a package name, not a fully qualified filename (for instance, in a Debian GNU/Linux system, libc6 would be the argument provided, not libc6_1.9.6-2.deb). All packages required by the package(s) specified for installation will also be retrieved and installed. The /etc/apt/sources.list file is used to locate the desired packages. If a hyphen is appended to the package name (with no intervening space), the identified package will be removed if it is installed. Similarly a plus sign can be used to designate a package to install. These latter features may be used to override decisions made by apt-get's conflict resolution system.

A specific version of a package can be selected for installation by following the package name with an equals and the version of the package to select. This will cause that version to be located and selected for install. Alternatively a specific distribution can be selected by following the package name with a slash and the version of the distribution or the Archive name (stable, testing, unstable).

Both of the version selection mechanisms can downgrade packages and must be used with care.

Finally, the apt_preferences mechanism allows creating an alternative installation policy for individual packages.

If no package matches the given expression and the expression contains one of '.', '?' or '*' then it is assumed to be a POSIX regular expression, and it is applied to all package names in the database. Any matches are then installed (or removed). Note that matching is done by substring so 'lo.*' matches 'how-lo' and 'lowest'. If this is undesired, anchor the regular expression with a '^' or '$' character, or create a more specific regular expression.

[edit] Update, upgrade and dist-upgrade

  • Update is used to resynchronize the package index files from their sources. The indices of available packages are fetched from the location(s) specified in /etc/apt/sources.list. For example, when using a Debian archive, this command retrieves and scans the Packages.gz files, so that information about new and updated packages is available. An update should always be performed before an upgrade or dist-upgrade. Be aware that the overall progress meter will be incorrect as the size of the package files cannot be known in advance.
  • 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, 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. The /etc/apt/sources.list file contains a list of locations from which to retrieve desired package files.

[edit] Configuration and Files

/etc/apt has the apt configuration folders and files.

apt-config is the APT Configuration Query program. [7] apt-config dump shows the configuration. [8]

[edit] Files

  • /etc/apt/sources.list : Locations to fetch packages from.
  • /etc/apt/apt.conf : APT configuration file.
  • /etc/apt/apt.conf.d/ : APT configuration file fragments .
  • /etc/apt/preferences : version preferences file. This is where you would specify "pinning", i.e. a preference to get certain packages from a separate source or from a different version of a distribution.
  • /var/cache/apt/archives/ : storage area for retrieved package files.
  • /var/cache/apt/archives/partial/  : storage area for package files in transit.
  • /var/lib/apt/lists/ : storage area for state information for each package resource specified in sources.list
  • /var/lib/apt/lists/partial/  : storage area for state information in transit.

[edit] Sources

APT relies on the concept of repositories in order to find software and resolve dependencies. For apt, a repository is a directory containing packages along with an index file. The Debian project keeps a central repository of over 19,000 software packages ready for download and installation.

For extra packages, any number of additional repositories can be added to APT's sources.list configuration file (/etc/apt/sources.list) and then be queried by APT. Graphical front-ends often allow modify source.list more simply (apt-setup). Once a package repository has been specified (like during the system installation), packages in that repository can be installed without specifying a source.

In addition to network repositories, compact discs and other storage media (USB keydrive, hard disks...) can be used as well, using apt-cdrom [9] or adding file:/ [10] to the source list file. Apt-cdrom can specify a different folder than a cd-rom, using the -d option (i.e. a hard disk or a USB keydrive). The Debian CDs available for download contain Debian repositories. This allows non-networked machines to be upgraded. Also one can use apt-zip.

Problems may appear when several sources offer the same package(s). Systems that have such possibly conflicting sources can use APT pinning to control which sources should be preferred.

[edit] APT pinning

APT pinning is a feature which allows administrators to force APT to choose particular versions of packages which may be available in different versions from different repositories. This allows administrators to ensure that packages are not upgraded to versions which may conflict with other packages on the system, or that have not been sufficiently tested for unwelcome changes.

In order to do this, the pins in APT's preferences file (/etc/apt/preferences) must be modified,[11] although graphical front-ends often allow this more simply.

[edit] History

The original effort that led to the apt-get program was the dselect replacement project known by its codename deity.[12] This project was commissioned by Brian White, the Debian Release Manager at the time. The very first functional version of apt-get was called dpkg-get and was only intended to be a test program for the core library functions that would underpin the new UI.[13]

Much of the original development of APT was done on IRC so records have been lost. The 'Deity Creation Team' mailing list archives include only the major highlights.

The Deity name was abandoned as the official name for the project due to concerns over the religious nature of the name. The APT name was eventually decided after considerable internal and public discussion. Ultimately the name was proposed on IRC, accepted and then finalized on the mailing lists.[14] As originally used APT is not an acronym, but a proper name. The name gained mindshare during IRC discussions[citation needed] due to the variety of possible acronym expansions and it was ultimately decided that the official use of APT would be as a proper name and no official expansion would ever be presented by the team.

APT was introduced in 1998 and original test builds were circulated on IRC. The first Debian version that included it was Debian 2.1, released on 9 March 1999.[15]

In the end the original goal of the Deity project of replacing the dselect UI was a failure. Work on the user interface (UI) portion of the project was abandoned (the UI directories were removed from the CVS system) after the first public release of apt-get. The response to APT as a dselect method and a command line utility was so great and positive that all development efforts focused on maintaining and improving the tool. It wasn't until much later that several independent people built UIs on top of the capable libapt-pkg.

The final push of the first APT era was to build a complete dpkg replacement (libapt-inst). This project was also a failure, however the partial code found a use as part of the secretive 'Project Betsy' programme, which resulted in the highly efficient apt-ftparchive and libapt python bindings. After this the original author faded away and maintainership of APT languished.

Eventually a new team picked up the project, began to build new features and released version 0.6 of APT which introduced the Secure APT feature, using strong cryptographic signing to authenticate the package repositories.[16]

[edit] See also

[edit] References

  1. ^ Debian -- Details of package apt in etch. packages.debian.org. Retrieved on 2008-05-12.
  2. ^ Debian -- Details of package apt in sid. packages.debian.org. Retrieved on 2008-05-12.
  3. ^ a b apt-get(8) - Linux man page. linux.die.net. Retrieved on 2008-05-12.
  4. ^ Fink - About. www.finkproject.org. Retrieved on 2008-05-12.
  5. ^ http://cafelinux.org/OzOs/content/aptfoo-designs-1
  6. ^ Byfield, Bruce. An apt-get primer. Newsforge.
  7. ^ Apt-Config
  8. ^ Query APT Configuration Using apt-config - Debian Admin
  9. ^ apt-cdrom
  10. ^ i.e. Deb file:/mnt/install stable main contrib. non-free
  11. ^ Apt Pinning. Debian Wiki. Retrieved on 2006-09-19.
  12. ^ Deity Mailing List, 1997-04.
  13. ^ Deity Mailing List, 1998-03.
  14. ^ Deity Mailing List, 1998-03.
  15. ^ A Brief History of Debian. Debian.org.
  16. ^ Secure APT. Debian Wiki. Retrieved on 2006-09-05.

[edit] External links