chiark / gitweb /
cgroup: additional validity checks for cgroup attribute names
[elogind.git] / man / logind.conf.xml
1 <?xml version='1.0'?> <!--*-nxml-*-->
2 <?xml-stylesheet type="text/xsl" href="http://docbook.sourceforge.net/release/xsl/current/xhtml/docbook.xsl"?>
3 <!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
4         "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">
5
6 <!--
7   This file is part of systemd.
8
9   Copyright 2010 Lennart Poettering
10
11   systemd is free software; you can redistribute it and/or modify it
12   under the terms of the GNU Lesser General Public License as published by
13   the Free Software Foundation; either version 2.1 of the License, or
14   (at your option) any later version.
15
16   systemd is distributed in the hope that it will be useful, but
17   WITHOUT ANY WARRANTY; without even the implied warranty of
18   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19   Lesser General Public License for more details.
20
21   You should have received a copy of the GNU Lesser General Public License
22   along with systemd; If not, see <http://www.gnu.org/licenses/>.
23 -->
24
25 <refentry id="logind.conf">
26         <refentryinfo>
27                 <title>logind.conf</title>
28                 <productname>systemd</productname>
29
30                 <authorgroup>
31                         <author>
32                                 <contrib>Developer</contrib>
33                                 <firstname>Lennart</firstname>
34                                 <surname>Poettering</surname>
35                                 <email>lennart@poettering.net</email>
36                         </author>
37                 </authorgroup>
38         </refentryinfo>
39
40         <refmeta>
41                 <refentrytitle>logind.conf</refentrytitle>
42                 <manvolnum>5</manvolnum>
43         </refmeta>
44
45         <refnamediv>
46                 <refname>logind.conf</refname>
47                 <refpurpose>Login manager configuration file</refpurpose>
48         </refnamediv>
49
50         <refsynopsisdiv>
51                 <para><filename>/etc/systemd/logind.conf</filename></para>
52         </refsynopsisdiv>
53
54         <refsect1>
55                 <title>Description</title>
56
57                 <para>This file configures various parameters of the systemd login manager <citerefentry><refentrytitle>systemd-logind.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>.</para>
58
59         </refsect1>
60
61         <refsect1>
62                 <title>Options</title>
63
64                 <para>All options are configured in the
65                 <literal>[Login]</literal> section:</para>
66
67                 <variablelist>
68
69                         <varlistentry>
70                                 <term><varname>NAutoVTs=</varname></term>
71
72                                 <listitem><para>Takes a positive
73                                 integer. Configures how many virtual
74                                 terminals (VTs) to allocate by default
75                                 that -- when switched to and
76                                 previously unused --
77                                 <literal>autovt</literal> services are
78                                 automatically spawned on. These
79                                 services are instantiated from the
80                                 template unit
81                                 <filename>autovt@.service</filename>
82                                 for the respective VT TTY name,
83                                 e.g. <filename>autovt@tty4.service</filename>. By
84                                 default
85                                 <filename>autovt@.service</filename>
86                                 is linked to
87                                 <filename>getty@.service</filename>,
88                                 i.e. login prompts are started
89                                 dynamically as the user switches to
90                                 unused virtual terminals. Hence, this
91                                 parameter controls how many login
92                                 <literal>gettys</literal> are
93                                 available on the VTs. If a VT is
94                                 already used by some other subsystem
95                                 (for example a graphical login) this
96                                 kind of activation will not be
97                                 attempted. Note that the VT configured
98                                 in <varname>ReserveVT=</varname> is
99                                 always subject to this kind of
100                                 activation, even if it is not one of
101                                 VTs configured with the
102                                 <varname>NAutoVTs=</varname>
103                                 directive. Defaults to 6. When set to
104                                 0, automatic spawning of
105                                 <literal>autovt</literal> services is
106                                 disabled. </para></listitem>
107                         </varlistentry>
108
109                         <varlistentry>
110                                 <term><varname>ReserveVT=</varname></term>
111
112                                 <listitem><para>Takes a positive
113                                 integer. Configures the number of one
114                                 virtual terminal that shall
115                                 unconditionally be reserved for
116                                 <filename>autovt@.service</filename>
117                                 activation (see above). The VT
118                                 selected with this option will be
119                                 marked busy unconditionally so that no
120                                 other subsystem will allocate it. This
121                                 functionality is useful to ensure that
122                                 regardless how many VTs are allocated
123                                 by other subsystems one login
124                                 <literal>getty</literal> is always
125                                 available. Defaults to 6 (with other
126                                 words: there'll always be a
127                                 <literal>getty</literal> available on
128                                 Alt-F6.). When set to 0, VT
129                                 reservation is
130                                 disabled.</para></listitem>
131                         </varlistentry>
132
133                         <varlistentry>
134                                 <term><varname>KillUserProcesses=</varname></term>
135
136                                 <listitem><para>Takes a boolean
137                                 argument. Configures whether the
138                                 processes of a user should be killed
139                                 when she or he completely logs out (i.e. after
140                                 her/his last session ended). Defaults to
141                                 <literal>no</literal>.</para></listitem>
142                         </varlistentry>
143
144                         <varlistentry>
145                                 <term><varname>IdleAction=</varname></term>
146
147                                 <listitem><para>Configures the action
148                                 to take when the system is idle. Takes
149                                 one of <literal>ignore</literal>,
150                                 <literal>poweroff</literal>,
151                                 <literal>reboot</literal>,
152                                 <literal>halt</literal>,
153                                 <literal>kexec</literal>,
154                                 <literal>suspend</literal>,
155                                 <literal>hibernate</literal>,
156                                 <literal>hybrid-sleep</literal>,
157                                 <literal>lock</literal>. Defaults to
158                                 <literal>ignore</literal>.</para>
159
160                                 <para>Note that this requires that
161                                 user sessions correctly report the
162                                 idle status to the system. The system
163                                 will execute the action after all
164                                 sessions reported that they are idle,
165                                 and no idle inhibitor lock is active,
166                                 and subsquently the time configured
167                                 with <varname>IdleActionSec=</varname>
168                                 (see below) has passed.</para>
169                                 </listitem>
170                         </varlistentry>
171
172                         <varlistentry>
173                                 <term><varname>IdleActionSec=</varname></term>
174
175                                 <listitem><para>Configures the delay
176                                 after which the action configured in
177                                 <varname>IdleAction=</varname> (see
178                                 above) is taken after the system is
179                                 idle.</para></listitem>
180                         </varlistentry>
181
182                         <varlistentry>
183                                 <term><varname>KillOnlyUsers=</varname></term>
184                                 <term><varname>KillExcludeUsers=</varname></term>
185
186                                 <listitem><para>These settings take
187                                 space separated lists of user names
188                                 that influence the effect of
189                                 <varname>KillUserProcesses=</varname>. If
190                                 not empty only processes of users
191                                 listed in
192                                 <varname>KillOnlyUsers</varname> will
193                                 be killed when they log out
194                                 entirely. Processes of users listed in
195                                 <varname>KillExcludeUsers=</varname>
196                                 are excluded from being
197                                 killed. <varname>KillExcludeUsers=</varname>
198                                 defaults to <literal>root</literal>
199                                 and takes precedence over
200                                 <varname>KillOnlyUsers=</varname>
201                                 which defaults to the empty list.</para></listitem>
202                         </varlistentry>
203
204                         <varlistentry>
205                                 <term><varname>Controllers=</varname></term>
206                                 <term><varname>ResetControllers=</varname></term>
207
208                                 <listitem><para>These settings control
209                                 the default control group hierarchies
210                                 users logging in are added to. When
211                                 logging in users will get private
212                                 control groups in all hierarchies
213                                 listed in
214                                 <varname>Controllers=</varname> and be
215                                 reset to the root control group in all
216                                 hierarchies listed in
217                                 <varname>ResetControllers=</varname>. <varname>Controllers=</varname>
218                                 defaults to the empty list,
219                                 <varname>ResetControllers=</varname>
220                                 defaults to
221                                 <literal>cpu</literal>.</para></listitem>
222                         </varlistentry>
223
224                         <varlistentry>
225                                 <term><varname>InhibitDelayMaxSec=</varname></term>
226
227                                 <listitem><para>Specifies the maximum
228                                 time a system shutdown or sleep
229                                 request is delayed due to an inhibitor
230                                 lock of type <literal>delay</literal>
231                                 being active -- before it is ignored
232                                 and the operation executed
233                                 anyway. Defaults to
234                                 5s.</para></listitem>
235                         </varlistentry>
236
237                         <varlistentry>
238                                 <term><varname>HandlePowerKey=</varname></term>
239                                 <term><varname>HandleSuspendKey=</varname></term>
240                                 <term><varname>HandleHibernateKey=</varname></term>
241                                 <term><varname>HandleLidSwitch=</varname></term>
242
243                                 <listitem><para>Controls whether
244                                 logind shall handle the system power
245                                 and sleep keys and the lid switch to
246                                 trigger actions such as system
247                                 power-off or suspend. Can be one of
248                                 <literal>ignore</literal>,
249                                 <literal>poweroff</literal>,
250                                 <literal>reboot</literal>,
251                                 <literal>halt</literal>,
252                                 <literal>kexec</literal>,
253                                 <literal>suspend</literal>,
254                                 <literal>hibernate</literal>,
255                                 <literal>hybrid-sleep</literal> and
256                                 <literal>lock</literal>. If
257                                 <literal>ignore</literal> logind will
258                                 never handle these keys. If
259                                 <literal>lock</literal> all running
260                                 sessions will be screen
261                                 locked. Otherwise the specified action
262                                 will be taken in the respective
263                                 event. Only input devices with the
264                                 <literal>power-switch</literal> udev
265                                 tag will be watched for key/lid switch
266                                 events. <varname>HandlePowerKey=</varname>
267                                 defaults to
268                                 <literal>poweroff</literal>.
269                                 <varname>HandleSuspendKey=</varname>
270                                 and
271                                 <varname>HandleLidSwitch=</varname>
272                                 default to <literal>suspend</literal>.
273                                 <varname>HandleHibernateKey=</varname>
274                                 defaults to
275                                 <literal>hibernate</literal>.</para></listitem>
276                         </varlistentry>
277
278                         <varlistentry>
279                                 <term><varname>PowerKeyIgnoreInhibited=</varname></term>
280                                 <term><varname>SuspendKeyIgnoreInhibited=</varname></term>
281                                 <term><varname>HibernateKeyIgnoreInhibited=</varname></term>
282                                 <term><varname>LidSwitchIgnoreInhibited=</varname></term>
283
284                                 <listitem><para>Controls whether
285                                 actions triggered by the power and
286                                 sleep keys and the lid switch are
287                                 subject to inhibitor locks. These
288                                 settings take boolean arguments. If
289                                 <literal>off</literal> the inhibitor
290                                 locks taken by applications in order
291                                 to block the requested operation are
292                                 respected, if <literal>on</literal>
293                                 the requested operation is executed in
294                                 any
295                                 case. <varname>PowerKeyIgnoreInhibited=</varname>,
296                                 <varname>SuspendKeyIgnoreInhibited=</varname>
297                                 and
298                                 <varname>HibernateKeyIgnoreInhibited=</varname>
299                                 defaults to <literal>off</literal>,
300                                 <varname>LidSwitchIgnoreInhibited=</varname>
301                                 defaults to
302                                 <literal>yes</literal>. This means
303                                 that the lid switch does not respect
304                                 suspend blockers by default, but the
305                                 power and sleep keys do.
306                                 </para></listitem>
307                         </varlistentry>
308
309                 </variablelist>
310
311                 <para>Note that setting
312                 <varname>KillUserProcesses=1</varname> will break tools
313                 like
314                 <citerefentry><refentrytitle>screen</refentrytitle><manvolnum>1</manvolnum></citerefentry>.</para>
315
316                 <para>Note that <varname>KillUserProcesses=1</varname>
317                 is a weaker version of
318                 <varname>kill-session-processes=1</varname> which may
319                 be configured per-service for
320                 <citerefentry><refentrytitle>pam_systemd</refentrytitle><manvolnum>8</manvolnum></citerefentry>. The
321                 latter kills processes of a session as soon as it
322                 ends, the former kills processes as soon as the last
323                 session of the user ends.</para>
324         </refsect1>
325
326         <refsect1>
327                   <title>See Also</title>
328                   <para>
329                           <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>,
330                           <citerefentry><refentrytitle>systemd-logind.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>,
331                           <citerefentry><refentrytitle>loginctl</refentrytitle><manvolnum>1</manvolnum></citerefentry>,
332                           <citerefentry><refentrytitle>systemd.conf</refentrytitle><manvolnum>5</manvolnum></citerefentry>
333                   </para>
334         </refsect1>
335
336 </refentry>