1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-25 10:04:04 +03:00

man: update systemctl man page for unit file commands, in particular "systemctl enable"

Clarify that "systemctl enable" can operate either on unit names or on unit
file paths (also, adjust the --help text to clarify this). Say that "systemctl
enable" on unit file paths also links the unit into the search path.

Many other fixes.

This should improve the documentation to avoid further confusion around #3706.
This commit is contained in:
Lennart Poettering 2016-07-25 15:10:15 +02:00
parent fec46f48b6
commit 3990961df0
2 changed files with 84 additions and 97 deletions

View File

@ -973,70 +973,62 @@ kobject-uevent 1 systemd-udevd-kernel.socket systemd-udevd.service
<term><command>list-unit-files <optional><replaceable>PATTERN...</replaceable></optional></command></term> <term><command>list-unit-files <optional><replaceable>PATTERN...</replaceable></optional></command></term>
<listitem> <listitem>
<para>List unit files installed in the file system and their enablement state <para>List unit files installed on the system, in combination with their enablement state (as reported by
(as reported by <command>is-enabled</command>). If one or more <command>is-enabled</command>). If one or more <replaceable>PATTERN</replaceable>s are specified, only unit
<replaceable>PATTERN</replaceable>s are specified, only units whose filename files whose name matches one of them are shown (patterns matching unit file system paths are not
(just the last component of the path) matches one of them are shown.</para> supported).</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
<varlistentry> <varlistentry>
<term><command>enable <replaceable>NAME</replaceable>...</command></term> <term><command>enable <replaceable>NAME</replaceable>...</command></term>
<term><command>enable <replaceable>PATH</replaceable>...</command></term>
<listitem> <listitem>
<para>Enable one or more unit files or unit file instances, <para>Enable one or more units or unit instances. This will create a set of symlinks, as encoded in the
as specified on the command line. This will create a number <literal>[Install]</literal> sections of the indicated unit files. After the symlinks have been created,
of symlinks as encoded in the <literal>[Install]</literal> the system manager configuration is reloaded (in a way equivalent to <command>daemon-reload</command>), in
sections of the unit files. After the symlinks have been order to ensure the changes are taken into account immediately. Note that this does
created, the systemd configuration is reloaded (in a way that <emphasis>not</emphasis> have the effect of also starting any of the units being enabled. If this is
is equivalent to <command>daemon-reload</command>) to ensure desired, combine this command with the <option>--now</option> switch, or invoke <command>start</command>
the changes are taken into account immediately. Note that with appropriate arguments later. Note that in case of unit instance enablement (i.e. enablement of units of
this does <emphasis>not</emphasis> have the effect of also the form <filename>foo@bar.service</filename>), symlinks named the same as instances are created in the
starting any of the units being enabled. If this unit configuration diectory, however they point to the single template unit file they are instantiated
is desired, either <option>--now</option> should be used from.</para>
together with this command, or an additional <command>start</command>
command must be invoked for the unit. Also note that, in case of
instance enablement, symlinks named the same as instances
are created in the install location, however they all point to the
same template unit file.</para>
<para>This command will print the actions executed. This <para>This command expects either valid unit names (in which case appropriate unit files for these names
output may be suppressed by passing <option>--quiet</option>. are automatically searched in the various unit file directories), or absolute paths to unit files (in which
case these files are read directly). If a specified unit file is located outside of the unit file
directories searched automatically, an additional symlink is created, linking it into the unit
configuration path, thus ensuring it is automatically found when requested by commands such as
<command>start</command>.</para>
<para>This command will print the file system operations executed. This output may be suppressed by passing
<option>--quiet</option>.
</para> </para>
<para>Note that this operation creates only the suggested <para>Note that this operation creates only the symlinks suggested in the <literal>[Install]</literal>
symlinks for the units. While this command is the section of the unit files. While this command is the recommended way to manipulate the unit configuration
recommended way to manipulate the unit configuration directory, the administrator is free to make additional changes manually by placing or removing symlinks
directory, the administrator is free to make additional below this directory. This is particularly useful to create configurations that deviate from the suggested
changes manually by placing or removing symlinks in the default installation. In this case, the administrator must make sure to invoke
directory. This is particularly useful to create <command>daemon-reload</command> manually as necessary, in order to ensure the changes are taken into
configurations that deviate from the suggested default account.
installation. In this case, the administrator must make sure
to invoke <command>daemon-reload</command> manually as
necessary to ensure the changes are taken into account.
</para> </para>
<para>Enabling units should not be confused with starting <para>Enabling units should not be confused with starting (activating) units, as done by the
(activating) units, as done by the <command>start</command> <command>start</command> command. Enabling and starting units is orthogonal: units may be enabled without
command. Enabling and starting units is orthogonal: units being started and started without being enabled. Enabling simply hooks the unit into various suggested
may be enabled without being started and started without places (for example, so that the unit is automatically started on boot or when a particular kind of
being enabled. Enabling simply hooks the unit into various hardware is plugged in). Starting actually spawns the daemon process (in case of service units), or binds
suggested places (for example, so that the unit is the socket (in case of socket units), and so on.</para>
automatically started on boot or when a particular kind of
hardware is plugged in). Starting actually spawns the daemon
process (in case of service units), or binds the socket (in
case of socket units), and so on.</para>
<para>Depending on whether <option>--system</option>, <para>Depending on whether <option>--system</option>, <option>--user</option>, <option>--runtime</option>,
<option>--user</option>, <option>--runtime</option>, or <option>--global</option> is specified, this enables the unit for the system, for the calling user only,
or <option>--global</option> is specified, this enables the unit for only this boot of the system, or for all future logins of all users, or only this boot. Note that in
for the system, for the calling user only, for only this boot of the last case, no systemd daemon configuration is reloaded.</para>
the system, or for all future logins of all users, or only this
boot. Note that in the last case, no systemd daemon
configuration is reloaded.</para>
<para>Using <command>enable</command> on masked units <para>Using <command>enable</command> on masked units is not supported and results in an error.</para>
results in an error.</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
@ -1044,28 +1036,31 @@ kobject-uevent 1 systemd-udevd-kernel.socket systemd-udevd.service
<term><command>disable <replaceable>NAME</replaceable>...</command></term> <term><command>disable <replaceable>NAME</replaceable>...</command></term>
<listitem> <listitem>
<para>Disables one or more units. This removes all symlinks <para>Disables one or more units. This removes all symlinks to the unit files backing the specified units
to the specified unit files from the unit configuration from the unit configuration directory, and hence undoes any changes made by <command>enable</command> or
directory, and hence undoes the changes made by <command>link</command>. Note that this removes <emphasis>all</emphasis> symlinks to matching unit files,
<command>enable</command>. Note however that this removes including manually created symlinks, and not just those actually created by <command>enable</command> or
all symlinks to the unit files (i.e. including manual <command>link</command>. Note that while <command>disable</command> undoes the effect of
additions), not just those actually created by <command>enable</command>, the two commands are otherwise not symmetric, as <command>disable</command> may
<command>enable</command>. This call implicitly reloads the remove more symlinks than a prior <command>enable</command> invocation of the same unit created.</para>
systemd daemon configuration after completing the disabling
of the units. Note that this command does not implicitly
stop the units that are being disabled. If this is desired, either
<option>--now</option> should be used together with this command, or
an additional <command>stop</command> command should be executed
afterwards.</para>
<para>This command will print the actions executed. This <para>This command expects valid unit names only, it does not accept paths to unit files.</para>
output may be suppressed by passing <option>--quiet</option>.
<para>In addition to the units specified as arguments, all units are disabled that are listed in the
<varname>Also=</varname> setting contained in the <literal>[Install]</literal> section of any of the unit
files being operated on.</para>
<para>This command implicitly reloads the system manager configuration after completing the operation. Note
that this command does not implicitly stop the units that are being disabled. If this is desired, either
combine this command with the <option>--now</option> switch, or invoke the <command>stop</command> command
with appropriate arguments later.</para>
<para>This command will print information about the file system operations (symlink removals)
executed. This output may be suppressed by passing <option>--quiet</option>.
</para> </para>
<para>This command honors <option>--system</option>, <para>This command honors <option>--system</option>, <option>--user</option>, <option>--runtime</option>
<option>--user</option>, <option>--runtime</option> and and <option>--global</option> in a similar way as <command>enable</command>.</para>
<option>--global</option> in a similar way as
<command>enable</command>.</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
@ -1073,12 +1068,10 @@ kobject-uevent 1 systemd-udevd-kernel.socket systemd-udevd.service
<term><command>reenable <replaceable>NAME</replaceable>...</command></term> <term><command>reenable <replaceable>NAME</replaceable>...</command></term>
<listitem> <listitem>
<para>Reenable one or more unit files, as specified on the <para>Reenable one or more units, as specified on the command line. This is a combination of
command line. This is a combination of <command>disable</command> and <command>enable</command> and is useful to reset the symlinks a unit file is
<command>disable</command> and <command>enable</command> and enabled with to the defaults configured in its <literal>[Install]</literal> section. This commands expects
is useful to reset the symlinks a unit is enabled with to a unit uname only, it does not accept paths to unit files.</para>
the defaults configured in the <literal>[Install]</literal>
section of the unit file.</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
@ -1209,16 +1202,13 @@ kobject-uevent 1 systemd-udevd-kernel.socket systemd-udevd.service
<term><command>mask <replaceable>NAME</replaceable>...</command></term> <term><command>mask <replaceable>NAME</replaceable>...</command></term>
<listitem> <listitem>
<para>Mask one or more unit files, as specified on the <para>Mask one or more units, as specified on the command line. This will link these unit files to
command line. This will link these units to <filename>/dev/null</filename>, making it impossible to start them. This is a stronger version of
<filename>/dev/null</filename>, making it impossible to <command>disable</command>, since it prohibits all kinds of activation of the unit, including enablement
start them. This is a stronger version of and manual activation. Use this option with care. This honors the <option>--runtime</option> option to only
<command>disable</command>, since it prohibits all kinds of mask temporarily until the next reboot of the system. The <option>--now</option> option may be used to
activation of the unit, including enablement and manual ensure that the units are also stopped. This command expects valid unit names only, it does not accept unit
activation. Use this option with care. This honors the file paths.</para>
<option>--runtime</option> option to only mask temporarily
until the next reboot of the system. The <option>--now</option>
option can be used to ensure that the units are also stopped.</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
@ -1226,23 +1216,20 @@ kobject-uevent 1 systemd-udevd-kernel.socket systemd-udevd.service
<term><command>unmask <replaceable>NAME</replaceable>...</command></term> <term><command>unmask <replaceable>NAME</replaceable>...</command></term>
<listitem> <listitem>
<para>Unmask one or more unit files, as specified on the <para>Unmask one or more unit files, as specified on the command line. This will undo the effect of
command line. This will undo the effect of <command>mask</command>. This command expects valid unit names only, it does not accept unit file
<command>mask</command>.</para> paths.</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
<varlistentry> <varlistentry>
<term><command>link <replaceable>FILENAME</replaceable>...</command></term> <term><command>link <replaceable>PATH</replaceable>...</command></term>
<listitem> <listitem>
<para>Link a unit file that is not in the unit file search <para>Link a unit file that is not in the unit file search paths into the unit file search path. This
paths into the unit file search path. This requires an command expects an absolute path to a unit file. The effect of this may be undone with
absolute path to a unit file. The effect of this can be <command>disable</command>. The effect of this command is that a unit file is made available for commands
undone with <command>disable</command>. The effect of this such as <command>start</command>, even though it is not installed directly in the unit search path.</para>
command is that a unit file is available for
<command>start</command> and other commands although it
is not installed directly in the unit search path.</para>
</listitem> </listitem>
</varlistentry> </varlistentry>

View File

@ -6533,7 +6533,7 @@ static void systemctl_help(void) {
" unit is required or wanted\n\n" " unit is required or wanted\n\n"
"Unit File Commands:\n" "Unit File Commands:\n"
" list-unit-files [PATTERN...] List installed unit files\n" " list-unit-files [PATTERN...] List installed unit files\n"
" enable NAME... Enable one or more unit files\n" " enable [NAME...|PATH...] Enable one or more unit files\n"
" disable NAME... Disable one or more unit files\n" " disable NAME... Disable one or more unit files\n"
" reenable NAME... Reenable one or more unit files\n" " reenable NAME... Reenable one or more unit files\n"
" preset NAME... Enable/disable one or more unit files\n" " preset NAME... Enable/disable one or more unit files\n"