[ Martin Pitt ]
[ntk/apt.git] / doc / apt_preferences.5.xml
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>
35 and the fragment files in the <filename>/etc/apt/preferences.d/</filename>
36 folder can be used to control which versions of packages will be selected
37 for installation.</para>
38
39 <para>Several versions of a package may be available for installation when
40 the &sources-list; file contains references to more than one distribution
41 (for example, <literal>stable</literal> and <literal>testing</literal>).
42 APT assigns a priority to each version that is available.
43 Subject to dependency constraints, <command>apt-get</command> selects the
44 version with the highest priority for installation.
45 The APT preferences file overrides the priorities that APT assigns to
46 package versions by default, thus giving the user control over which
47 one is selected for installation.</para>
48
49 <para>Several instances of the same version of a package may be available when
50 the &sources-list; file contains references to more than one source.
51 In this case <command>apt-get</command> downloads the instance listed
52 earliest in the &sources-list; file.
53 The APT preferences file does not affect the choice of instance, only
54 the choice of version.</para>
55
56 <para>Preferences are a strong power in the hands of a system administrator
57 but they can become also their biggest nightmare if used without care!
58 APT will not questioning the preferences so wrong settings will therefore
59 lead to uninstallable packages or wrong decisions while upgrading packages.
60 Even more problems will arise if multiply distribution releases are mixed
61 without a good understanding of the following paragraphs.
62 Packages included in a specific release aren't tested in and
63 therefore doesn't always work as expected in older or newer releases or
64 together with other packages from different releases.
65 You have been warned.</para>
66
67 <para>Note that the files in the <filename>/etc/apt/preferences.d</filename>
68 directory are parsed in alphanumeric ascending order and need to obey the
69 following naming convention: The files have no or "<literal>pref</literal>"
70 as filename extension and which only contain alphanumeric, hyphen (-),
71 underscore (_) and period (.) characters - otherwise they will be silently
72 ignored.</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
77 that applies to a particular version then the priority assigned to that
78 version is the priority of the distribution to which that version
79 belongs. It is possible to single out a distribution, "the target release",
80 which receives a higher priority than other distributions do by default.
81 The target release can be set on the <command>apt-get</command> command
82 line or in the APT configuration file <filename>/etc/apt/apt.conf</filename>.
83 Note that this has precedence over any general priority you set in the
84 <filename>/etc/apt/preferences</filename> file described later, but not
85 over specifically pinned packages.
86 For example,
87
88 <programlisting>
89 <command>apt-get install -t testing <replaceable>some-package</replaceable></command>
90 </programlisting>
91 <programlisting>
92 APT::Default-Release "stable";
93 </programlisting>
94 </para>
95
96 <para>If the target release has been specified then APT uses the following
97 algorithm 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>
103 files 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
124 priority 100 to all installed package versions and priority 500 to all
125 uninstalled package versions, expect versions coming from archives which
126 in their <filename>Release</filename> files are marked as "NotAutomatic: yes" -
127 these versions get the priority 1.</para>
128
129 <para>APT then applies the following rules, listed in order of precedence,
130 to determine which version of a package to install.
131 <itemizedlist>
132 <listitem><simpara>Never downgrade unless the priority of an available
133 version exceeds 1000. ("Downgrading" is installing a less recent version
134 of a package in place of a more recent version. Note that none of APT's
135 default priorities exceeds 1000; such high priorities can only be set in
136 the preferences file. Note also that downgrading a package
137 can 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,
140 install the most recent one (that is, the one with the higher version
141 number).</simpara></listitem>
142 <listitem><simpara>If two or more versions have the same priority and
143 version 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)
149 is not as recent as one of the versions available from the sources listed in
150 the &sources-list; file (priority 500 or 990). Then the package will be upgraded
151 when <command>apt-get install <replaceable>some-package</replaceable></command>
152 or <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
156 than any of the other available versions. The package will not be downgraded
157 when <command>apt-get install <replaceable>some-package</replaceable></command>
158 or <command>apt-get upgrade</command> is executed.</para>
159
160 <para>Sometimes the installed version of a package is more recent than the
161 version belonging to the target release, but not as recent as a version
162 belonging to some other distribution. Such a package will indeed be upgraded
163 when <command>apt-get install <replaceable>some-package</replaceable></command>
164 or <command>apt-get upgrade</command> is executed,
165 because at least <emphasis>one</emphasis> of the available versions has a higher
166 priority 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
172 assignment of priorities. The file consists of one or more multi-line records
173 separated by blank lines. Records can have one of two forms, a specific form
174 and a general form.
175 <itemizedlist>
176 <listitem>
177 <simpara>The specific form assigns a priority (a "Pin-Priority") to one or more
178 specified packages and specified version or version range. For example,
179 the following record assigns a high priority to all versions of
180 the <filename>perl</filename> package whose version number begins with "<literal>5.8</literal>".
181 Multiple packages can be separated by spaces.</simpara>
182
183 <programlisting>
184 Package: perl
185 Pin: version 5.8*
186 Pin-Priority: 1001
187 </programlisting>
188 </listitem>
189
190 <listitem><simpara>The general form assigns a priority to all of the package versions in a
191 given distribution (that is, to all the versions of packages that are
192 listed in a certain <filename>Release</filename> file) or to all of the package
193 versions coming from a particular Internet site, as identified by the
194 site's fully qualified domain name.</simpara>
195
196 <simpara>This general-form entry in the APT preferences file applies only
197 to groups of packages. For example, the following record assigns a high
198 priority to all package versions available from the local site.</simpara>
199
200 <programlisting>
201 Package: *
202 Pin: origin ""
203 Pin-Priority: 999
204 </programlisting>
205
206 <simpara>A note of caution: the keyword used here is "<literal>origin</literal>"
207 which can be used to match a hostname. The following record will assign a high priority
208 to all versions available from the server identified by the hostname "ftp.de.debian.org"</simpara>
209 <programlisting>
210 Package: *
211 Pin: origin "ftp.de.debian.org"
212 Pin-Priority: 999
213 </programlisting>
214 <simpara>This should <emphasis>not</emphasis> be confused with the Origin of a distribution as
215 specified in a <filename>Release</filename> file. What follows the "Origin:" tag
216 in a <filename>Release</filename> file is not an Internet address
217 but 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
220 belonging to any distribution whose Archive name is "<literal>unstable</literal>".</simpara>
221
222 <programlisting>
223 Package: *
224 Pin: release a=unstable
225 Pin-Priority: 50
226 </programlisting>
227
228 <simpara>The following record assigns a high priority to all package versions
229 belonging to any distribution whose Codename is "<literal>&testing-codename;</literal>".</simpara>
230
231 <programlisting>
232 Package: *
233 Pin: release n=&testing-codename;
234 Pin-Priority: 900
235 </programlisting>
236
237 <simpara>The following record assigns a high priority to all package versions
238 belonging to any release whose Archive name is "<literal>stable</literal>"
239 and whose release Version number is "<literal>3.0</literal>".</simpara>
240
241 <programlisting>
242 Package: *
243 Pin: release a=stable, v=3.0
244 Pin-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>
256 Priorities (P) assigned in the APT preferences file must be positive
257 or 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
263 constitutes 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
268 even if it does not come from the target release,
269 unless 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
274 unless there is a version available belonging to the target release
275 or 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
280 unless there is a version available belonging to some other
281 distribution 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
286 only 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
296 first such record determines the priority of the package version.
297 Failing that,
298 if any general-form records match an available package version then the
299 first such record determines the priority of the package version.</para>
300
301 <para>For example, suppose the APT preferences file contains the three
302 records presented earlier:</para>
303
304 <programlisting>
305 Package: perl
306 Pin: version 5.8*
307 Pin-Priority: 1001
308
309 Package: *
310 Pin: origin ""
311 Pin-Priority: 999
312
313 Package: *
314 Pin: release unstable
315 Pin-Priority: 50
316 </programlisting>
317
318 <para>Then:
319 <itemizedlist>
320 <listitem><simpara>The most recent available version of the <literal>perl</literal>
321 package will be installed, so long as that version's version number begins
322 with "<literal>5.8</literal>". If <emphasis>any</emphasis> 5.8* version of <literal>perl</literal> is
323 available and the installed version is 5.9*, then <literal>perl</literal> will be
324 downgraded.</simpara></listitem>
325 <listitem><simpara>A version of any package other than <literal>perl</literal>
326 that is available from the local system has priority over other versions,
327 even versions belonging to the target release.
328 </simpara></listitem>
329 <listitem><simpara>A version of a package whose origin is not the local
330 system but some other site listed in &sources-list; and which belongs to
331 an <literal>unstable</literal> distribution is only installed if it is selected
332 for 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
343 to 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>:
347 for example, <filename>.../dists/stable/main/binary-i386/Packages</filename>.
348 It consists of a series of multi-line records, one for each package available
349 in that directory. Only two lines in each record are relevant for setting
350 APT 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>:
365 for example, <filename>.../dists/stable/Release</filename>,
366 or <filename>.../dists/&stable-codename;/Release</filename>.
367 It consists of a single multi-line record which applies to <emphasis>all</emphasis> of
368 the 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>
370 file 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
376 in the directory tree belong. For example, the line
377 "Archive: stable" or
378 "Suite: stable"
379 specifies that all of the packages in the directory
380 tree 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
382 would require the line:
383 </simpara>
384 <programlisting>
385 Pin: 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
393 in the directory tree belong. For example, the line
394 "Codename: &testing-codename;"
395 specifies that all of the packages in the directory
396 tree 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
398 would require the line:
399 </simpara>
400 <programlisting>
401 Pin: 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
409 packages in the tree might belong to Debian GNU/Linux release
410 version 3.0. Note that there is normally no version number for the
411 <literal>testing</literal> and <literal>unstable</literal> distributions because they
412 have not been released yet. Specifying this in the APT preferences
413 file would require one of the following lines.
414 </simpara>
415
416 <programlisting>
417 Pin: release v=3.0
418 Pin: release a=stable, v=3.0
419 Pin: 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
428 packages in the directory tree of the <filename>Release</filename> file.
429 For example, the line "Component: main" specifies that
430 all the packages in the directory tree are from the <literal>main</literal>
431 component, which entails that they are licensed under terms listed
432 in the Debian Free Software Guidelines. Specifying this component
433 in the APT preferences file would require the line:
434 </simpara>
435 <programlisting>
436 Pin: 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
444 directory tree of the <filename>Release</filename> file. Most commonly, this is
445 <literal>Debian</literal>. Specifying this origin in the APT preferences file
446 would require the line:
447 </simpara>
448 <programlisting>
449 Pin: 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
457 of the <filename>Release</filename> file. Most commonly, this is
458 <literal>Debian</literal>. Specifying this label in the APT preferences file
459 would require the line:
460 </simpara>
461 <programlisting>
462 Pin: 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>
470 files retrieved from locations listed in the &sources-list; file are stored
471 in the directory <filename>/var/lib/apt/lists</filename>, or in the file named
472 by the variable <literal>Dir::State::Lists</literal> in the <filename>apt.conf</filename> file.
473 For example, the file
474 <filename>debian.lcs.mit.edu_debian_dists_unstable_contrib_binary-i386_Release</filename>
475 contains the <filename>Release</filename> file retrieved from the site
476 <literal>debian.lcs.mit.edu</literal> for <literal>binary-i386</literal> architecture
477 files from the <literal>contrib</literal> component of the <literal>unstable</literal>
478 distribution.</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
485 one or more lines beginning with the word <literal>Explanation:</literal>.
486 This 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
496 priority higher than the default (500) to all package versions belonging
497 to a <literal>stable</literal> distribution and a prohibitively low priority to
498 package versions belonging to other <literal>Debian</literal> distributions.
499
500 <programlisting>
501 Explanation: Uninstall or do not install any Debian-originated
502 Explanation: package versions other than those in the stable distro
503 Package: *
504 Pin: release a=stable
505 Pin-Priority: 900
506
507 Package: *
508 Pin: release o=Debian
509 Pin-Priority: -10
510 </programlisting>
511 </para>
512
513 <para>With a suitable &sources-list; file and the above preferences file,
514 any of the following commands will cause APT to upgrade to the
515 latest <literal>stable</literal> version(s).
516
517 <programlisting>
518 apt-get install <replaceable>package-name</replaceable>
519 apt-get upgrade
520 apt-get dist-upgrade
521 </programlisting>
522 </para>
523
524 <para>The following command will cause APT to upgrade the specified
525 package to the latest version from the <literal>testing</literal> distribution;
526 the package will not be upgraded again unless this command is given
527 again.
528
529 <programlisting>
530 apt-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
539 a high priority to package versions from the <literal>testing</literal>
540 distribution, a lower priority to package versions from the
541 <literal>unstable</literal> distribution, and a prohibitively low priority
542 to package versions from other <literal>Debian</literal> distributions.
543
544 <programlisting>
545 Package: *
546 Pin: release a=testing
547 Pin-Priority: 900
548
549 Package: *
550 Pin: release a=unstable
551 Pin-Priority: 800
552
553 Package: *
554 Pin: release o=Debian
555 Pin-Priority: -10
556 </programlisting>
557 </para>
558
559 <para>With a suitable &sources-list; file and the above preferences file,
560 any of the following commands will cause APT to upgrade to the latest
561 <literal>testing</literal> version(s).
562
563 <programlisting>
564 apt-get install <replaceable>package-name</replaceable>
565 apt-get upgrade
566 apt-get dist-upgrade
567 </programlisting>
568 </para>
569
570 <para>The following command will cause APT to upgrade the specified
571 package to the latest version from the <literal>unstable</literal> distribution.
572 Thereafter, <command>apt-get upgrade</command> will upgrade
573 the package to the most recent <literal>testing</literal> version if that is
574 more recent than the installed version, otherwise, to the most recent
575 <literal>unstable</literal> version if that is more recent than the installed
576 version.
577
578 <programlisting>
579 apt-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
589 priority higher than the default (500) to all package versions belonging
590 to a specified codename of a distribution and a prohibitively low priority to
591 package versions belonging to other <literal>Debian</literal> distributions,
592 codenames and archives.
593 Note that with this APT preference APT will follow the migration of a release
594 from the archive <literal>testing</literal> to <literal>stable</literal> and
595 later <literal>oldstable</literal>. If you want to follow for example the progress
596 in <literal>testing</literal> notwithstanding the codename changes you should use
597 the example configurations above.
598
599 <programlisting>
600 Explanation: Uninstall or do not install any Debian-originated package versions
601 Explanation: other than those in the distribution codenamed with &testing-codename; or sid
602 Package: *
603 Pin: release n=&testing-codename;
604 Pin-Priority: 900
605
606 Explanation: Debian unstable is always codenamed with sid
607 Package: *
608 Pin: release n=sid
609 Pin-Priority: 800
610
611 Package: *
612 Pin: release o=Debian
613 Pin-Priority: -10
614 </programlisting>
615 </para>
616
617 <para>With a suitable &sources-list; file and the above preferences file,
618 any of the following commands will cause APT to upgrade to the
619 latest version(s) in the release codenamed with <literal>&testing-codename;</literal>.
620
621 <programlisting>
622 apt-get install <replaceable>package-name</replaceable>
623 apt-get upgrade
624 apt-get dist-upgrade
625 </programlisting>
626 </para>
627
628 <para>The following command will cause APT to upgrade the specified
629 package to the latest version from the <literal>sid</literal> distribution.
630 Thereafter, <command>apt-get upgrade</command> will upgrade
631 the package to the most recent <literal>&testing-codename;</literal> version if that is
632 more recent than the installed version, otherwise, to the most recent
633 <literal>sid</literal> version if that is more recent than the installed
634 version.
635
636 <programlisting>
637 apt-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>