X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=man%2Fsysctl.d.xml;h=3002ebd0fdc13bcbca3206793e0e7fac2ea4a5c9;hp=20f2e24820e53e2d38225a5e5593c526a1a12dc4;hb=1b600437bac3c0676cc72f589909c4cbfe38ba10;hpb=95f77929d8d94480015cd7383a5504cf9ebf2fa5 diff --git a/man/sysctl.d.xml b/man/sysctl.d.xml index 20f2e2482..3002ebd0f 100644 --- a/man/sysctl.d.xml +++ b/man/sysctl.d.xml @@ -7,16 +7,16 @@ Copyright 2011 Lennart Poettering systemd is free software; you can redistribute it and/or modify it - under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or + under the terms of the GNU Lesser General Public License as published by + the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. systemd is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - General Public License for more details. + Lesser General Public License for more details. - You should have received a copy of the GNU General Public License + You should have received a copy of the GNU Lesser General Public License along with systemd; If not, see . --> @@ -54,60 +54,136 @@ Description - systemd uses configuration - files from the above directories to configure - sysctl8 - kernel parameters during boot. + At boot, + systemd-sysctl.service8 + reads configuration files from the above directories + to configure + sysctl8 + kernel parameters. - Configuration Format + Configuration Format - The configuration files contain a list of - variable assignments, separated by newlines. Empty - lines and lines whose first non-whitespace character - is # or ; are ignored. - - Note that both / and . are accepted as label - separators within sysctl variable - names. kernel.domainname=foo and - kernel/domainname=foo hence are - entirely equivalent. + The configuration files contain a list of + variable assignments, separated by newlines. Empty + lines and lines whose first non-whitespace character + is # or ; are + ignored. Each configuration file shall be named in the - style of <program>.conf. - Files in /run/ override files - with the same name in /usr/lib/. - Files in /etc override files with - the same name in /run/ and - /usr/lib/. Packages should - install their configuration files in + style of program.conf. + Files in /etc/ override files + with the same name in /usr/lib/ + and /run/. Files in + /run/ override files with the same + name in /usr/lib/. Packages + should install their configuration files in /usr/lib/. Files in /etc/ are reserved for the local administrator, who may use this logic to override the - configuration installed by vendor packages. All - configuration files are sorted by their name in - alphabetical order, regardless in which of the - directories they reside, to guarantee that a specific - configuration file takes precedence over another file - with an alphabetically earlier name, if both files - contain the same variable setting. + configuration files installed by vendor packages. All + configuration files are sorted by their filename in + lexicographic order, regardless of which of the + directories they reside in. If multiple files specify the + same variable name, the entry in the file with the + lexicographically latest name will be applied. It is + recommended to prefix all filenames with a two-digit + number and a dash, to simplify the ordering of the + files. + + Note that either / or + . may be used as separators within + sysctl variable names. If the first separator is a + slash, remaining slashes and dots are left intact. If + the first separator is a dot, dots and slashes are + interchanged. kernel.domainname=foo + and kernel/domainname=foo are + equivalent and will cause foo to + be written to + /proc/sys/kernel/domainname. + Either + net.ipv4.conf.enp3s0/200.forwarding + or + net/ipv4/conf/enp3s0.200/forwarding + may be used to refer to + /proc/sys/net/ipv4/conf/enp3s0.200/forwarding. + If the administrator wants to disable a - configuration file supplied by the vendor the + configuration file supplied by the vendor, the recommended way is to place a symlink to /dev/null in - /etc/sysctl.d carrying with the - same name. + /etc/sysctl.d/ bearing the + same filename. + + The settings configured with + sysctl.d files will be applied + early on boot. The network interface-specific options + will also be applied individually for each network + interface as it shows up in the system. (More + specifically, + net.ipv4.conf.*, + net.ipv6.conf.*, + net.ipv4.neigh.* and net.ipv6.neigh.*). + + Many sysctl parameters only become available + when certain kernel modules are loaded. Modules are + usually loaded on demand, e.g. when certain hardware + is plugged in or network brought up. This means that + systemd-sysctl.service8 which runs + during early boot will not configure such parameters + if they become available after it has run. To + set such parameters, it is recommended to add + an udev7 rule to set those parameters when they become + available. Alternatively, a slightly simpler and + less efficient option is to add the module to + modules-load.d5, causing it to be loaded statically + before sysctl settings are applied (see + example below). - Example + Examples + + Set kernel YP domain name + /etc/sysctl.d/domain-name.conf: + + + kernel.domainname=example.com + + + + Disable packet filter on bridged packets (method one) + /etc/udev/rules.d/99-bridge.rules: + + + ACTION=="add", SUBSYSTEM=="module", KERNEL=="bridge", RUN+="/usr/lib/systemd/systemd-sysctl --prefix=/net/bridge" + + + /etc/sysctl.d/bridge.conf: + + + net.bridge.bridge-nf-call-ip6tables = 0 +net.bridge.bridge-nf-call-iptables = 0 +net.bridge.bridge-nf-call-arptables = 0 + + + - /etc/sysctl.d/domain-name.conf example: + Disable packet filter on bridged packets (method two) + /etc/modules-load.d/bridge.conf: + + + bridge + + /etc/sysctl.d/bridge.conf: + - # Set kernel YP domain name -kernel.domainname=example.com + net.bridge.bridge-nf-call-ip6tables = 0 +net.bridge.bridge-nf-call-iptables = 0 +net.bridge.bridge-nf-call-arptables = 0 + @@ -115,8 +191,11 @@ kernel.domainname=example.com See Also systemd1, + systemd-sysctl.service8, + systemd-delta1, sysctl8, sysctl.conf5 + modprobe8