sysctl
Vorzugsweise für das Linux Kernel-Tuning verwendet.
„all“ vs „default“ in sysctl-Parametern
Was ist der Unterschied zwischen „all“, „default“ oder Geräte-spezifischen Settings in sysctl
? Beispiel:
net.ipv4.conf.all.accept_source_route = 0
net.ipv4.conf.default.accept_source_route = 0
net.ipv4.conf.enp1s0.accept_source_route = 1
„all“ ändert die Einstellung für alle existierenden Geräte, egal welche Einstellung die Geräte selbst besitzen - ausser die Geräteeinstellung ist grösser als der „all“-Wert.
„default“ ist die Standardeinstellung für neu hinzugefügte, spezifische Geräte.
Die im Beispiel angeführte Einstellung für „enp1s0“ gilt nur für das Gerät. Damit ergibt sich:
enp1s0:
accept_source_route = 1
eth0:
accept_source_route = 0
Achtung
RHEL 7+ kann abhängig von der Hardware bereits NIC-Treiber laden, bevor die sysctl-Defaults zur Anwendung kommen. Um sicherzugehen, dass die sysctl-Einstellungen gelten, sollte man wie auf https://access.redhat.com/solutions/8694 beschrieben ein /sbin/ifup-local
verwenden, welches die Einstellungen für das Interface lädt. Beispiel für solch ein Script:
#!/bin/bash
sysctl net.ipv4.conf.$1.rp_filter=2
Falls der NetworkManager zum Einsatz kommt, muss stattdessen ein NetworkManager Dispatcher Script erstellt werden, das vom NetworkManager ausgeführt wird, sobald der Link-State auf up oder down wechselt - abzulegen im Beispiel unter /etc/NetworkManager/dispatcher.d/30-rp_filter
Settings, die sofort aktiv werden
Settings, die ohne Reboot geändert werden können.
# Usage example: set_kparm vm.swapiness 10
set_kparm () {
echo "Previous value: $(sysctl $1)"
echo "$1 = $2" >> /etc/sysctl.conf
sysctl -p > /dev/null
echo "Current value: $(sysctl $1)"
}
Swapiness auf „10“ setzen (RHEL swappt erst, wenn nur noch 10% RAM oder weniger frei sind):
set_kparm vm.swappiness 10
Settings, die erst nach einem Reboot aktiv werden
qdisc ändern:
# view the current config
sysctl net.core.default_qdisc
# Default RHEL 7: pfifo_fast
# Default RHEL 8: fq_codel
# view the current config
yum -y install iproute-tc
tc -s qdisc show dev eth0
# qdisc fq_codel 0: ...
# update the existing qdisc
set_kparm net.core.default_qdisc pfifo_fast
# reboot necessary
reboot
Built on 2025-01-06