]> git.saurik.com Git - apt.git/blame_incremental - doc/apt_preferences.5.xml
* apt-pkg/contrib/fileutl.cc:
[apt.git] / doc / apt_preferences.5.xml
... / ...
CommitLineData
1<?xml version="1.0" encoding="utf-8" standalone="no"?>
2<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
3 "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd" [
4
5<!ENTITY % aptent SYSTEM "apt.ent">
6%aptent;
7
8]>
9
10<refentry>
11
12 <refentryinfo>
13 &apt-author.team;
14 &apt-email;
15 &apt-product;
16 <!-- The last update date -->
17 <date>16 February 2010</date>
18 </refentryinfo>
19
20 <refmeta>
21 <refentrytitle>apt_preferences</refentrytitle>
22 <manvolnum>5</manvolnum>
23 <refmiscinfo class="manual">APT</refmiscinfo>
24 </refmeta>
25
26 <!-- Man page title -->
27 <refnamediv>
28 <refname>apt_preferences</refname>
29 <refpurpose>Preference control file for APT</refpurpose>
30 </refnamediv>
31
32<refsect1>
33<title>Description</title>
34<para>The APT preferences file <filename>/etc/apt/preferences</filename>
35and the fragment files in the <filename>/etc/apt/preferences.d/</filename>
36folder can be used to control which versions of packages will be selected
37for installation.</para>
38
39<para>Several versions of a package may be available for installation when
40the &sources-list; file contains references to more than one distribution
41(for example, <literal>stable</literal> and <literal>testing</literal>).
42APT assigns a priority to each version that is available.
43Subject to dependency constraints, <command>apt-get</command> selects the
44version with the highest priority for installation.
45The APT preferences file overrides the priorities that APT assigns to
46package versions by default, thus giving the user control over which
47one is selected for installation.</para>
48
49<para>Several instances of the same version of a package may be available when
50the &sources-list; file contains references to more than one source.
51In this case <command>apt-get</command> downloads the instance listed
52earliest in the &sources-list; file.
53The APT preferences file does not affect the choice of instance, only
54the choice of version.</para>
55
56<para>Preferences are a strong power in the hands of a system administrator
57but they can become also their biggest nightmare if used without care!
58APT will not questioning the preferences so wrong settings will therefore
59lead to uninstallable packages or wrong decisions while upgrading packages.
60Even more problems will arise if multiply distribution releases are mixed
61without a good understanding of the following paragraphs.
62Packages included in a specific release aren't tested in and
63therefore doesn't always work as expected in older or newer releases or
64together with other packages from different releases.
65You have been warned.</para>
66
67<para>Note that the files in the <filename>/etc/apt/preferences.d</filename>
68directory are parsed in alphanumeric ascending order and need to obey the
69following naming convention: The files have no or "<literal>pref</literal>"
70as filename extension and which only contain alphanumeric, hyphen (-),
71underscore (_) and period (.) characters - otherwise they will be silently
72ignored.</para>
73
74<refsect2><title>APT's Default Priority Assignments</title>
75
76<para>If there is no preferences file or if there is no entry in the file
77that applies to a particular version then the priority assigned to that
78version is the priority of the distribution to which that version
79belongs. It is possible to single out a distribution, "the target release",
80which receives a higher priority than other distributions do by default.
81The target release can be set on the <command>apt-get</command> command
82line or in the APT configuration file <filename>/etc/apt/apt.conf</filename>.
83Note that this has precedence over any general priority you set in the
84<filename>/etc/apt/preferences</filename> file described later, but not
85over specifically pinned packages.
86For example,
87
88<programlisting>
89<command>apt-get install -t testing <replaceable>some-package</replaceable></command>
90</programlisting>
91<programlisting>
92APT::Default-Release "stable";
93</programlisting>
94</para>
95
96<para>If the target release has been specified then APT uses the following
97algorithm to set the priorities of the versions of a package. Assign:
98
99<variablelist>
100<varlistentry>
101<term>priority 1</term>
102<listitem><simpara>to the versions coming from archives which in their <filename>Release</filename>
103files are marked as "NotAutomatic: yes" like the debian experimental archive.</simpara></listitem>
104</varlistentry>
105
106<varlistentry>
107<term>priority 100</term>
108<listitem><simpara>to the version that is already installed (if any).</simpara></listitem>
109</varlistentry>
110
111<varlistentry>
112<term>priority 500</term>
113<listitem><simpara>to the versions that are not installed and do not belong to the target release.</simpara></listitem>
114</varlistentry>
115
116<varlistentry>
117<term>priority 990</term>
118<listitem><simpara>to the versions that are not installed and belong to the target release.</simpara></listitem>
119</varlistentry>
120</variablelist>
121</para>
122
123<para>If the target release has not been specified then APT simply assigns
124priority 100 to all installed package versions and priority 500 to all
125uninstalled package versions, expect versions coming from archives which
126in their <filename>Release</filename> files are marked as "NotAutomatic: yes" -
127these versions get the priority 1.</para>
128
129<para>APT then applies the following rules, listed in order of precedence,
130to determine which version of a package to install.
131<itemizedlist>
132<listitem><simpara>Never downgrade unless the priority of an available
133version exceeds 1000. ("Downgrading" is installing a less recent version
134of a package in place of a more recent version. Note that none of APT's
135default priorities exceeds 1000; such high priorities can only be set in
136the preferences file. Note also that downgrading a package
137can be risky.)</simpara></listitem>
138<listitem><simpara>Install the highest priority version.</simpara></listitem>
139<listitem><simpara>If two or more versions have the same priority,
140install the most recent one (that is, the one with the higher version
141number).</simpara></listitem>
142<listitem><simpara>If two or more versions have the same priority and
143version number but either the packages differ in some of their metadata or the
144<literal>--reinstall</literal> option is given, install the uninstalled one.</simpara></listitem>
145</itemizedlist>
146</para>
147
148<para>In a typical situation, the installed version of a package (priority 100)
149is not as recent as one of the versions available from the sources listed in
150the &sources-list; file (priority 500 or 990). Then the package will be upgraded
151when <command>apt-get install <replaceable>some-package</replaceable></command>
152or <command>apt-get upgrade</command> is executed.
153</para>
154
155<para>More rarely, the installed version of a package is <emphasis>more</emphasis> recent
156than any of the other available versions. The package will not be downgraded
157when <command>apt-get install <replaceable>some-package</replaceable></command>
158or <command>apt-get upgrade</command> is executed.</para>
159
160<para>Sometimes the installed version of a package is more recent than the
161version belonging to the target release, but not as recent as a version
162belonging to some other distribution. Such a package will indeed be upgraded
163when <command>apt-get install <replaceable>some-package</replaceable></command>
164or <command>apt-get upgrade</command> is executed,
165because at least <emphasis>one</emphasis> of the available versions has a higher
166priority than the installed version.</para>
167</refsect2>
168
169<refsect2><title>The Effect of APT Preferences</title>
170
171<para>The APT preferences file allows the system administrator to control the
172assignment of priorities. The file consists of one or more multi-line records
173separated by blank lines. Records can have one of two forms, a specific form
174and a general form.
175<itemizedlist>
176<listitem>
177<simpara>The specific form assigns a priority (a "Pin-Priority") to one or more
178specified packages and specified version or version range. For example,
179the following record assigns a high priority to all versions of
180the <filename>perl</filename> package whose version number begins with "<literal>5.8</literal>".
181Multiple packages can be separated by spaces.</simpara>
182
183<programlisting>
184Package: perl
185Pin: version 5.8*
186Pin-Priority: 1001
187</programlisting>
188</listitem>
189
190<listitem><simpara>The general form assigns a priority to all of the package versions in a
191given distribution (that is, to all the versions of packages that are
192listed in a certain <filename>Release</filename> file) or to all of the package
193versions coming from a particular Internet site, as identified by the
194site's fully qualified domain name.</simpara>
195
196<simpara>This general-form entry in the APT preferences file applies only
197to groups of packages. For example, the following record assigns a high
198priority to all package versions available from the local site.</simpara>
199
200<programlisting>
201Package: *
202Pin: origin ""
203Pin-Priority: 999
204</programlisting>
205
206<simpara>A note of caution: the keyword used here is "<literal>origin</literal>"
207which can be used to match a hostname. The following record will assign a high priority
208to all versions available from the server identified by the hostname "ftp.de.debian.org"</simpara>
209<programlisting>
210Package: *
211Pin: origin "ftp.de.debian.org"
212Pin-Priority: 999
213</programlisting>
214<simpara>This should <emphasis>not</emphasis> be confused with the Origin of a distribution as
215specified in a <filename>Release</filename> file. What follows the "Origin:" tag
216in a <filename>Release</filename> file is not an Internet address
217but an author or vendor name, such as "Debian" or "Ximian".</simpara>
218
219<simpara>The following record assigns a low priority to all package versions
220belonging to any distribution whose Archive name is "<literal>unstable</literal>".</simpara>
221
222<programlisting>
223Package: *
224Pin: release a=unstable
225Pin-Priority: 50
226</programlisting>
227
228<simpara>The following record assigns a high priority to all package versions
229belonging to any distribution whose Codename is "<literal>&testing-codename;</literal>".</simpara>
230
231<programlisting>
232Package: *
233Pin: release n=&testing-codename;
234Pin-Priority: 900
235</programlisting>
236
237<simpara>The following record assigns a high priority to all package versions
238belonging to any release whose Archive name is "<literal>stable</literal>"
239and whose release Version number is "<literal>3.0</literal>".</simpara>
240
241<programlisting>
242Package: *
243Pin: release a=stable, v=3.0
244Pin-Priority: 500
245</programlisting>
246</listitem>
247</itemizedlist>
248</para>
249
250</refsect2>
251
252<refsect2>
253<title>How APT Interprets Priorities</title>
254
255<para>
256Priorities (P) assigned in the APT preferences file must be positive
257or negative integers. They are interpreted as follows (roughly speaking):
258
259<variablelist>
260<varlistentry>
261<term>P &gt; 1000</term>
262<listitem><simpara>causes a version to be installed even if this
263constitutes a downgrade of the package</simpara></listitem>
264</varlistentry>
265<varlistentry>
266<term>990 &lt; P &lt;=1000</term>
267<listitem><simpara>causes a version to be installed
268even if it does not come from the target release,
269unless the installed version is more recent</simpara></listitem>
270</varlistentry>
271<varlistentry>
272<term>500 &lt; P &lt;=990</term>
273<listitem><simpara>causes a version to be installed
274unless there is a version available belonging to the target release
275or the installed version is more recent</simpara></listitem>
276</varlistentry>
277<varlistentry>
278<term>100 &lt; P &lt;=500</term>
279<listitem><simpara>causes a version to be installed
280unless there is a version available belonging to some other
281distribution or the installed version is more recent</simpara></listitem>
282</varlistentry>
283<varlistentry>
284<term>0 &lt; P &lt;=100</term>
285<listitem><simpara>causes a version to be installed
286only if there is no installed version of the package</simpara></listitem>
287</varlistentry>
288<varlistentry>
289<term>P &lt; 0</term>
290<listitem><simpara>prevents the version from being installed</simpara></listitem>
291</varlistentry>
292</variablelist>
293</para>
294
295<para>If any specific-form records match an available package version then the
296first such record determines the priority of the package version.
297Failing that,
298if any general-form records match an available package version then the
299first such record determines the priority of the package version.</para>
300
301<para>For example, suppose the APT preferences file contains the three
302records presented earlier:</para>
303
304<programlisting>
305Package: perl
306Pin: version 5.8*
307Pin-Priority: 1001
308
309Package: *
310Pin: origin ""
311Pin-Priority: 999
312
313Package: *
314Pin: release unstable
315Pin-Priority: 50
316</programlisting>
317
318<para>Then:
319<itemizedlist>
320<listitem><simpara>The most recent available version of the <literal>perl</literal>
321package will be installed, so long as that version's version number begins
322with "<literal>5.8</literal>". If <emphasis>any</emphasis> 5.8* version of <literal>perl</literal> is
323available and the installed version is 5.9*, then <literal>perl</literal> will be
324downgraded.</simpara></listitem>
325<listitem><simpara>A version of any package other than <literal>perl</literal>
326that is available from the local system has priority over other versions,
327even versions belonging to the target release.
328</simpara></listitem>
329<listitem><simpara>A version of a package whose origin is not the local
330system but some other site listed in &sources-list; and which belongs to
331an <literal>unstable</literal> distribution is only installed if it is selected
332for installation and no version of the package is already installed.
333</simpara></listitem>
334</itemizedlist>
335</para>
336</refsect2>
337
338<refsect2>
339<title>Determination of Package Version and Distribution Properties</title>
340
341<para>The locations listed in the &sources-list; file should provide
342<filename>Packages</filename> and <filename>Release</filename> files
343to describe the packages available at that location. </para>
344
345<para>The <filename>Packages</filename> file is normally found in the directory
346<filename>.../dists/<replaceable>dist-name</replaceable>/<replaceable>component</replaceable>/<replaceable>arch</replaceable></filename>:
347for example, <filename>.../dists/stable/main/binary-i386/Packages</filename>.
348It consists of a series of multi-line records, one for each package available
349in that directory. Only two lines in each record are relevant for setting
350APT priorities:
351<variablelist>
352<varlistentry>
353<term>the <literal>Package:</literal> line</term>
354<listitem><simpara>gives the package name</simpara></listitem>
355</varlistentry>
356<varlistentry>
357<term>the <literal>Version:</literal> line</term>
358<listitem><simpara>gives the version number for the named package</simpara></listitem>
359</varlistentry>
360</variablelist>
361</para>
362
363<para>The <filename>Release</filename> file is normally found in the directory
364<filename>.../dists/<replaceable>dist-name</replaceable></filename>:
365for example, <filename>.../dists/stable/Release</filename>,
366or <filename>.../dists/&stable-codename;/Release</filename>.
367It consists of a single multi-line record which applies to <emphasis>all</emphasis> of
368the packages in the directory tree below its parent. Unlike the
369<filename>Packages</filename> file, nearly all of the lines in a <filename>Release</filename>
370file are relevant for setting APT priorities:
371
372<variablelist>
373<varlistentry>
374<term>the <literal>Archive:</literal> or <literal>Suite:</literal> line</term>
375<listitem><simpara>names the archive to which all the packages
376in the directory tree belong. For example, the line
377"Archive: stable" or
378"Suite: stable"
379specifies that all of the packages in the directory
380tree below the parent of the <filename>Release</filename> file are in a
381<literal>stable</literal> archive. Specifying this value in the APT preferences file
382would require the line:
383</simpara>
384<programlisting>
385Pin: release a=stable
386</programlisting>
387</listitem>
388</varlistentry>
389
390<varlistentry>
391<term>the <literal>Codename:</literal> line</term>
392<listitem><simpara>names the codename to which all the packages
393in the directory tree belong. For example, the line
394"Codename: &testing-codename;"
395specifies that all of the packages in the directory
396tree below the parent of the <filename>Release</filename> file belong to a version named
397<literal>&testing-codename;</literal>. Specifying this value in the APT preferences file
398would require the line:
399</simpara>
400<programlisting>
401Pin: release n=&testing-codename;
402</programlisting>
403</listitem>
404</varlistentry>
405
406<varlistentry>
407<term>the <literal>Version:</literal> line</term>
408<listitem><simpara>names the release version. For example, the
409packages in the tree might belong to Debian GNU/Linux release
410version 3.0. Note that there is normally no version number for the
411<literal>testing</literal> and <literal>unstable</literal> distributions because they
412have not been released yet. Specifying this in the APT preferences
413file would require one of the following lines.
414</simpara>
415
416<programlisting>
417Pin: release v=3.0
418Pin: release a=stable, v=3.0
419Pin: release 3.0
420</programlisting>
421
422</listitem>
423</varlistentry>
424
425<varlistentry>
426<term>the <literal>Component:</literal> line</term>
427<listitem><simpara>names the licensing component associated with the
428packages in the directory tree of the <filename>Release</filename> file.
429For example, the line "Component: main" specifies that
430all the packages in the directory tree are from the <literal>main</literal>
431component, which entails that they are licensed under terms listed
432in the Debian Free Software Guidelines. Specifying this component
433in the APT preferences file would require the line:
434</simpara>
435<programlisting>
436Pin: release c=main
437</programlisting>
438</listitem>
439</varlistentry>
440
441<varlistentry>
442<term>the <literal>Origin:</literal> line</term>
443<listitem><simpara>names the originator of the packages in the
444directory tree of the <filename>Release</filename> file. Most commonly, this is
445<literal>Debian</literal>. Specifying this origin in the APT preferences file
446would require the line:
447</simpara>
448<programlisting>
449Pin: release o=Debian
450</programlisting>
451</listitem>
452</varlistentry>
453
454<varlistentry>
455<term>the <literal>Label:</literal> line</term>
456<listitem><simpara>names the label of the packages in the directory tree
457of the <filename>Release</filename> file. Most commonly, this is
458<literal>Debian</literal>. Specifying this label in the APT preferences file
459would require the line:
460</simpara>
461<programlisting>
462Pin: release l=Debian
463</programlisting>
464</listitem>
465</varlistentry>
466</variablelist>
467</para>
468
469<para>All of the <filename>Packages</filename> and <filename>Release</filename>
470files retrieved from locations listed in the &sources-list; file are stored
471in the directory <filename>/var/lib/apt/lists</filename>, or in the file named
472by the variable <literal>Dir::State::Lists</literal> in the <filename>apt.conf</filename> file.
473For example, the file
474<filename>debian.lcs.mit.edu_debian_dists_unstable_contrib_binary-i386_Release</filename>
475contains the <filename>Release</filename> file retrieved from the site
476<literal>debian.lcs.mit.edu</literal> for <literal>binary-i386</literal> architecture
477files from the <literal>contrib</literal> component of the <literal>unstable</literal>
478distribution.</para>
479</refsect2>
480
481<refsect2>
482<title>Optional Lines in an APT Preferences Record</title>
483
484<para>Each record in the APT preferences file can optionally begin with
485one or more lines beginning with the word <literal>Explanation:</literal>.
486This provides a place for comments.</para>
487</refsect2>
488</refsect1>
489
490<refsect1>
491<title>Examples</title>
492<refsect2>
493<title>Tracking Stable</title>
494
495<para>The following APT preferences file will cause APT to assign a
496priority higher than the default (500) to all package versions belonging
497to a <literal>stable</literal> distribution and a prohibitively low priority to
498package versions belonging to other <literal>Debian</literal> distributions.
499
500<programlisting>
501Explanation: Uninstall or do not install any Debian-originated
502Explanation: package versions other than those in the stable distro
503Package: *
504Pin: release a=stable
505Pin-Priority: 900
506
507Package: *
508Pin: release o=Debian
509Pin-Priority: -10
510</programlisting>
511</para>
512
513<para>With a suitable &sources-list; file and the above preferences file,
514any of the following commands will cause APT to upgrade to the
515latest <literal>stable</literal> version(s).
516
517<programlisting>
518apt-get install <replaceable>package-name</replaceable>
519apt-get upgrade
520apt-get dist-upgrade
521</programlisting>
522</para>
523
524<para>The following command will cause APT to upgrade the specified
525package to the latest version from the <literal>testing</literal> distribution;
526the package will not be upgraded again unless this command is given
527again.
528
529<programlisting>
530apt-get install <replaceable>package</replaceable>/testing
531</programlisting>
532</para>
533</refsect2>
534
535 <refsect2>
536 <title>Tracking Testing or Unstable</title>
537
538<para>The following APT preferences file will cause APT to assign
539a high priority to package versions from the <literal>testing</literal>
540distribution, a lower priority to package versions from the
541<literal>unstable</literal> distribution, and a prohibitively low priority
542to package versions from other <literal>Debian</literal> distributions.
543
544<programlisting>
545Package: *
546Pin: release a=testing
547Pin-Priority: 900
548
549Package: *
550Pin: release a=unstable
551Pin-Priority: 800
552
553Package: *
554Pin: release o=Debian
555Pin-Priority: -10
556</programlisting>
557</para>
558
559<para>With a suitable &sources-list; file and the above preferences file,
560any of the following commands will cause APT to upgrade to the latest
561<literal>testing</literal> version(s).
562
563<programlisting>
564apt-get install <replaceable>package-name</replaceable>
565apt-get upgrade
566apt-get dist-upgrade
567</programlisting>
568</para>
569
570<para>The following command will cause APT to upgrade the specified
571package to the latest version from the <literal>unstable</literal> distribution.
572Thereafter, <command>apt-get upgrade</command> will upgrade
573the package to the most recent <literal>testing</literal> version if that is
574more recent than the installed version, otherwise, to the most recent
575<literal>unstable</literal> version if that is more recent than the installed
576version.
577
578<programlisting>
579apt-get install <replaceable>package</replaceable>/unstable
580</programlisting>
581</para>
582</refsect2>
583
584
585<refsect2>
586<title>Tracking the evolution of a codename release</title>
587
588<para>The following APT preferences file will cause APT to assign a
589priority higher than the default (500) to all package versions belonging
590to a specified codename of a distribution and a prohibitively low priority to
591package versions belonging to other <literal>Debian</literal> distributions,
592codenames and archives.
593Note that with this APT preference APT will follow the migration of a release
594from the archive <literal>testing</literal> to <literal>stable</literal> and
595later <literal>oldstable</literal>. If you want to follow for example the progress
596in <literal>testing</literal> notwithstanding the codename changes you should use
597the example configurations above.
598
599<programlisting>
600Explanation: Uninstall or do not install any Debian-originated package versions
601Explanation: other than those in the distribution codenamed with &testing-codename; or sid
602Package: *
603Pin: release n=&testing-codename;
604Pin-Priority: 900
605
606Explanation: Debian unstable is always codenamed with sid
607Package: *
608Pin: release n=sid
609Pin-Priority: 800
610
611Package: *
612Pin: release o=Debian
613Pin-Priority: -10
614</programlisting>
615</para>
616
617<para>With a suitable &sources-list; file and the above preferences file,
618any of the following commands will cause APT to upgrade to the
619latest version(s) in the release codenamed with <literal>&testing-codename;</literal>.
620
621<programlisting>
622apt-get install <replaceable>package-name</replaceable>
623apt-get upgrade
624apt-get dist-upgrade
625</programlisting>
626</para>
627
628<para>The following command will cause APT to upgrade the specified
629package to the latest version from the <literal>sid</literal> distribution.
630Thereafter, <command>apt-get upgrade</command> will upgrade
631the package to the most recent <literal>&testing-codename;</literal> version if that is
632more recent than the installed version, otherwise, to the most recent
633<literal>sid</literal> version if that is more recent than the installed
634version.
635
636<programlisting>
637apt-get install <replaceable>package</replaceable>/sid
638</programlisting>
639</para>
640</refsect2>
641</refsect1>
642
643<refsect1>
644<title>Files</title>
645 <variablelist>
646 &file-preferences;
647 </variablelist>
648</refsect1>
649
650<refsect1>
651<title>See Also</title>
652<para>&apt-get; &apt-cache; &apt-conf; &sources-list;
653</para>
654</refsect1>
655
656 &manbugs;
657
658</refentry>