X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=man%2Fsysctl.d.xml;h=c67a199fb518513e39677a66ac59c1f805346fea;hp=db53b495998b27671662d0c31619305a6fd93670;hb=302fbdf29eb0ad4ca1fe8ee18755edad7db11b37;hpb=2e573fcf8754fdfe0db0a783b1631ec1679b063a diff --git a/man/sysctl.d.xml b/man/sysctl.d.xml index db53b4959..c67a199fb 100644 --- a/man/sysctl.d.xml +++ b/man/sysctl.d.xml @@ -1,5 +1,4 @@ - - + - + sysctl.d @@ -89,34 +89,6 @@ /proc/sys/net/ipv4/conf/enp3s0.200/forwarding. - Each configuration file shall be named in the - 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 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. - - If the administrator wants to disable a - configuration file supplied by the vendor, the - recommended way is to place a symlink to - /dev/null in - /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 @@ -125,16 +97,67 @@ specifically, net.ipv4.conf.*, net.ipv6.conf.*, - net.ipv4.neigh.* and net.ipv6.neigh.*) + 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 + @@ -145,7 +168,8 @@ kernel.domainname=example.com systemd-sysctl.service8, systemd-delta1, sysctl8, - sysctl.conf5 + sysctl.conf5, + modprobe8