mirror of
https://github.com/moby/moby.git
synced 2026-01-11 18:51:37 +00:00
I noticed these errors logged inside the dev-container;
ERRO[2025-10-14T16:15:46.603781797Z] error reading the kernel parameter net.ipv4.neigh.default.gc_thresh1 error="open /proc/sys/net/ipv4/neigh/default/gc_thresh1: no such file or directory"
ERRO[2025-10-14T16:15:46.603808089Z] error reading the kernel parameter net.ipv4.neigh.default.gc_thresh2 error="open /proc/sys/net/ipv4/neigh/default/gc_thresh2: no such file or directory"
ERRO[2025-10-14T16:15:46.603819922Z] error reading the kernel parameter net.ipv4.neigh.default.gc_thresh3 error="open /proc/sys/net/ipv4/neigh/default/gc_thresh3: no such file or directory"
Given that these happen during an initial check, we can probably ignore them
if there's nothing to tweak.
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
51 lines
1.5 KiB
Go
51 lines
1.5 KiB
Go
package kernel
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
"path"
|
|
"strings"
|
|
|
|
"github.com/containerd/log"
|
|
)
|
|
|
|
// writeSystemProperty writes the value to a path under /proc/sys as determined from the key.
|
|
// For e.g. net.ipv4.ip_forward translated to /proc/sys/net/ipv4/ip_forward.
|
|
func writeSystemProperty(key, value string) error {
|
|
keyPath := strings.ReplaceAll(key, ".", "/")
|
|
return os.WriteFile(path.Join("/proc/sys", keyPath), []byte(value), 0o644)
|
|
}
|
|
|
|
// readSystemProperty reads the value from the path under /proc/sys and returns it
|
|
func readSystemProperty(key string) (string, error) {
|
|
keyPath := strings.ReplaceAll(key, ".", "/")
|
|
value, err := os.ReadFile(path.Join("/proc/sys", keyPath))
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return strings.TrimSpace(string(value)), nil
|
|
}
|
|
|
|
// ApplyOSTweaks applies the configuration values passed as arguments
|
|
func ApplyOSTweaks(osConfig map[string]*OSValue) {
|
|
for k, v := range osConfig {
|
|
// read the existing property from disk
|
|
oldv, err := readSystemProperty(k)
|
|
if err != nil {
|
|
if !os.IsNotExist(err) {
|
|
log.G(context.TODO()).WithError(err).Errorf("error reading the kernel parameter %s", k)
|
|
}
|
|
continue
|
|
}
|
|
|
|
if propertyIsValid(oldv, v.Value, v.CheckFn) {
|
|
// write new prop value to disk
|
|
if err := writeSystemProperty(k, v.Value); err != nil {
|
|
log.G(context.TODO()).WithError(err).Warnf("error setting the kernel parameter %s = %s, (leaving as %s)", k, v.Value, oldv)
|
|
continue
|
|
}
|
|
log.G(context.TODO()).Debugf("updated kernel parameter %s = %s (was %s)", k, v.Value, oldv)
|
|
}
|
|
}
|
|
}
|