]> git.ipfire.org Git - thirdparty/systemd.git/blame - man/systemd.swap.xml
man: describe unit templating explicitly
[thirdparty/systemd.git] / man / systemd.swap.xml
CommitLineData
e0cabd4b 1<?xml version='1.0'?> <!--*-nxml-*-->
e0cabd4b 2<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
12b42c76 3 "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">
e0cabd4b
LP
4
5<!--
572eb058
ZJS
6 SPDX-License-Identifier: LGPL-2.1+
7
e0cabd4b
LP
8 This file is part of systemd.
9
10 Copyright 2010 Lennart Poettering
e0cabd4b
LP
11-->
12
13<refentry id="systemd.swap">
798d3a52
ZJS
14 <refentryinfo>
15 <title>systemd.swap</title>
16 <productname>systemd</productname>
17
18 <authorgroup>
19 <author>
20 <contrib>Developer</contrib>
21 <firstname>Lennart</firstname>
22 <surname>Poettering</surname>
23 <email>lennart@poettering.net</email>
24 </author>
25 </authorgroup>
26 </refentryinfo>
27
28 <refmeta>
29 <refentrytitle>systemd.swap</refentrytitle>
30 <manvolnum>5</manvolnum>
31 </refmeta>
32
33 <refnamediv>
34 <refname>systemd.swap</refname>
35 <refpurpose>Swap unit configuration</refpurpose>
36 </refnamediv>
37
38 <refsynopsisdiv>
39 <para><filename><replaceable>swap</replaceable>.swap</filename></para>
40 </refsynopsisdiv>
41
42 <refsect1>
43 <title>Description</title>
44
45 <para>A unit configuration file whose name ends in
46 <literal>.swap</literal> encodes information about a swap device
47 or file for memory paging controlled and supervised by
48 systemd.</para>
49
50 <para>This man page lists the configuration options specific to
51 this unit type. See
52 <citerefentry><refentrytitle>systemd.unit</refentrytitle><manvolnum>5</manvolnum></citerefentry>
53 for the common options of all unit configuration files. The common
54 configuration items are configured in the generic [Unit] and
55 [Install] sections. The swap specific configuration options are
56 configured in the [Swap] section.</para>
57
58 <para>Additional options are listed in
59 <citerefentry><refentrytitle>systemd.exec</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
c129bd5d
LP
60 which define the execution environment the <citerefentry
61 project='man-pages'><refentrytitle>swapon</refentrytitle><manvolnum>8</manvolnum></citerefentry>
3f2d1365 62 program is executed in, in
798d3a52 63 <citerefentry><refentrytitle>systemd.kill</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
c629ff58 64 which define the way these processes are
c129bd5d 65 terminated, and in
798d3a52 66 <citerefentry><refentrytitle>systemd.resource-control</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
c129bd5d
LP
67 which configure resource control settings for these processes of the
68 unit.</para>
798d3a52 69
f4bf8d2f
LP
70 <para>Swap units must be named after the devices or files they control. Example: the swap device <filename
71 noindex='true'>/dev/sda5</filename> must be configured in a unit file <filename>dev-sda5.swap</filename>. For
72 details about the escaping logic used to convert a file system path to a unit name, see
73 <citerefentry><refentrytitle>systemd.unit</refentrytitle><manvolnum>5</manvolnum></citerefentry>. Note that swap
74 units cannot be templated, nor is possible to add multiple names to a swap unit by creating additional symlinks to
75 it.</para>
c129bd5d
LP
76 </refsect1>
77
78 <refsect1>
45f09f93 79 <title>Implicit Dependencies</title>
798d3a52 80
45f09f93 81 <para>The following dependencies are implicitly added:</para>
798d3a52 82
45f09f93
JL
83 <itemizedlist>
84 <listitem><para>All swap units automatically get the
85 <varname>BindsTo=</varname> and <varname>After=</varname>
86 dependencies on the device units or the mount units of the files
87 they are activated from.</para></listitem>
88 </itemizedlist>
c129bd5d
LP
89
90 <para>Additional implicit dependencies may be added as result of
91 execution and resource control parameters as documented in
92 <citerefentry><refentrytitle>systemd.exec</refentrytitle><manvolnum>5</manvolnum></citerefentry>
93 and
94 <citerefentry><refentrytitle>systemd.resource-control</refentrytitle><manvolnum>5</manvolnum></citerefentry>.</para>
798d3a52
ZJS
95 </refsect1>
96
45f09f93
JL
97 <refsect1>
98 <title>Default Dependencies</title>
99
100 <para>The following dependencies are added unless <varname>DefaultDependencies=no</varname> is set:</para>
101
102 <itemizedlist>
103 <listitem><para>Swap units automatically acquire a <varname>Conflicts=</varname> and a
104 <varname>Before=</varname> dependency on <filename>umount.target</filename> so that they are deactivated at
105 shutdown as well as a <varname>Before=swap.target</varname> dependency.</para></listitem>
106 </itemizedlist>
107 </refsect1>
108
798d3a52
ZJS
109 <refsect1>
110 <title><filename>fstab</filename></title>
111
112 <para>Swap units may either be configured via unit files, or via
113 <filename>/etc/fstab</filename> (see
3ba3a79d 114 <citerefentry project='man-pages'><refentrytitle>fstab</refentrytitle><manvolnum>5</manvolnum></citerefentry>
798d3a52
ZJS
115 for details). Swaps listed in <filename>/etc/fstab</filename> will
116 be converted into native units dynamically at boot and when the
117 configuration of the system manager is reloaded. See
118 <citerefentry><refentrytitle>systemd-fstab-generator</refentrytitle><manvolnum>8</manvolnum></citerefentry>
119 for details about the conversion.</para>
120
121 <para>If a swap device or file is configured in both
122 <filename>/etc/fstab</filename> and a unit file, the configuration
123 in the latter takes precedence.</para>
124
b938cb90 125 <para>When reading <filename>/etc/fstab</filename>, a few special
798d3a52
ZJS
126 options are understood by systemd which influence how dependencies
127 are created for swap units.</para>
128
129 <variablelist class='fstab-options'>
130 <varlistentry>
131 <term><option>noauto</option></term>
132 <term><option>auto</option></term>
133
b938cb90 134 <listitem><para>With <option>noauto</option>, the swap unit
798d3a52
ZJS
135 will not be added as a dependency for
136 <filename>swap.target</filename>. This means that it will not
137 be activated automatically during boot, unless it is pulled in
a8eaaee7 138 by some other unit. The <option>auto</option> option has the
798d3a52
ZJS
139 opposite meaning and is the default.</para>
140 </listitem>
141 </varlistentry>
142
143 <varlistentry>
144 <term><option>nofail</option></term>
145
b938cb90 146 <listitem><para>With <option>nofail</option>, the swap unit
798d3a52
ZJS
147 will be only wanted, not required by
148 <filename>swap.target</filename>. This means that the boot
149 will continue even if this swap device is not activated
150 successfully.</para>
151 </listitem>
152 </varlistentry>
153 </variablelist>
154 </refsect1>
155
156 <refsect1>
157 <title>Options</title>
158
159 <para>Swap files must include a [Swap] section, which carries
160 information about the swap device it supervises. A number of
161 options that may be used in this section are shared with other
162 unit types. These options are documented in
163 <citerefentry><refentrytitle>systemd.exec</refentrytitle><manvolnum>5</manvolnum></citerefentry>
164 and
165 <citerefentry><refentrytitle>systemd.kill</refentrytitle><manvolnum>5</manvolnum></citerefentry>.
166 The options specific to the [Swap] section of swap units are the
167 following:</para>
168
169 <variablelist class='unit-directives'>
170
171 <varlistentry>
172 <term><varname>What=</varname></term>
19d0833b
LP
173 <listitem><para>Takes an absolute path of a device node or file to use for paging. See <citerefentry
174 project='man-pages'><refentrytitle>swapon</refentrytitle><manvolnum>8</manvolnum></citerefentry> for
175 details. If this refers to a device node, a dependency on the respective device unit is automatically
176 created. (See
177 <citerefentry><refentrytitle>systemd.device</refentrytitle><manvolnum>5</manvolnum></citerefentry> for more
178 information.) If this refers to a file, a dependency on the respective mount unit is automatically
179 created. (See <citerefentry><refentrytitle>systemd.mount</refentrytitle><manvolnum>5</manvolnum></citerefentry>
180 for more information.) This option is mandatory. Note that the usual specifier expansion is applied to this
181 setting, literal percent characters should hence be written as <literal>%%</literal>.</para></listitem>
798d3a52
ZJS
182 </varlistentry>
183
184 <varlistentry>
185 <term><varname>Priority=</varname></term>
186
187 <listitem><para>Swap priority to use when activating the swap
188 device or file. This takes an integer. This setting is
a8eaaee7
JE
189 optional and ignored when the priority is set by <option>pri=</option> in the
190 <varname>Options=</varname> key.</para></listitem>
798d3a52
ZJS
191 </varlistentry>
192
193 <varlistentry>
194 <term><varname>Options=</varname></term>
195
d5cc4be2
LP
196 <listitem><para>May contain an option string for the swap device. This may be used for controlling discard
197 options among other functionality, if the swap backing device supports the discard or trim operation. (See
3ba3a79d 198 <citerefentry project='man-pages'><refentrytitle>swapon</refentrytitle><manvolnum>8</manvolnum></citerefentry>
d5cc4be2
LP
199 for more information.) Note that the usual specifier expansion is applied to this setting, literal percent
200 characters should hence be written as <literal>%%</literal>.</para></listitem>
798d3a52
ZJS
201 </varlistentry>
202
203 <varlistentry>
204 <term><varname>TimeoutSec=</varname></term>
205 <listitem><para>Configures the time to wait for the swapon
206 command to finish. If a command does not exit within the
207 configured time, the swap will be considered failed and be
208 shut down again. All commands still running will be terminated
209 forcibly via <constant>SIGTERM</constant>, and after another
210 delay of this time with <constant>SIGKILL</constant>. (See
211 <option>KillMode=</option> in
212 <citerefentry><refentrytitle>systemd.kill</refentrytitle><manvolnum>5</manvolnum></citerefentry>.)
213 Takes a unit-less value in seconds, or a time span value such
214 as "5min 20s". Pass <literal>0</literal> to disable the
215 timeout logic. Defaults to
216 <varname>DefaultTimeoutStartSec=</varname> from the manager
217 configuration file (see
218 <citerefentry><refentrytitle>systemd-system.conf</refentrytitle><manvolnum>5</manvolnum></citerefentry>).
219 </para></listitem>
220 </varlistentry>
221 </variablelist>
222
223 <para>Check
224 <citerefentry><refentrytitle>systemd.exec</refentrytitle><manvolnum>5</manvolnum></citerefentry>
225 and
226 <citerefentry><refentrytitle>systemd.kill</refentrytitle><manvolnum>5</manvolnum></citerefentry>
227 for more settings.</para>
228 </refsect1>
229
230 <refsect1>
231 <title>See Also</title>
232 <para>
233 <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>,
234 <citerefentry><refentrytitle>systemctl</refentrytitle><manvolnum>1</manvolnum></citerefentry>,
235 <citerefentry><refentrytitle>systemd.unit</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
236 <citerefentry><refentrytitle>systemd.exec</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
237 <citerefentry><refentrytitle>systemd.kill</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
238 <citerefentry><refentrytitle>systemd.resource-control</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
239 <citerefentry><refentrytitle>systemd.device</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
240 <citerefentry><refentrytitle>systemd.mount</refentrytitle><manvolnum>5</manvolnum></citerefentry>,
3ba3a79d 241 <citerefentry project='man-pages'><refentrytitle>swapon</refentrytitle><manvolnum>8</manvolnum></citerefentry>,
798d3a52
ZJS
242 <citerefentry><refentrytitle>systemd-fstab-generator</refentrytitle><manvolnum>8</manvolnum></citerefentry>,
243 <citerefentry><refentrytitle>systemd.directives</refentrytitle><manvolnum>7</manvolnum></citerefentry>
244 </para>
245 </refsect1>
e0cabd4b
LP
246
247</refentry>