百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

linux配置内核参数

ahcoder 2025-03-10 11:56 9 浏览

简介

linux内核参数,在之前的版本都是配置/etc/sysctl.conf文件,在现在使用systemd管理的系统的系统中,默认没有这个文件。使用sysctl.d 在启动时配置内核参数。


配置目录

系统在启动的时候,systemd-sysctl.service服务会按照下面目录的顺序列出配置文件,进行加载

  1. /etc/sysctl.d/*.conf
  2. /run/sysctl.d/*.conf
  3. /usr/lib/sysctl.d/*.conf

配置文件的名称必须符合 filename.conf 格式。

对于不同目录下的同名配置文件,仅以优先级最高的目录中的那一个为准。


规范

软件包应该将自带的配置文件安装在 /usr/lib/sysctl.d/ 目录中。

/etc/sysctl.d/ 目录仅供系统管理员使用。

目录中的配置文件排序是按照文件名的字典顺序,如果有相同的配置项,在文件排序靠后的会覆盖前面的配置。

为了便于排序,建议给所有配置文件都加上两位十进制数字的文件名前缀。

例如:99-sys.conf、10-sysapp.conf

配置文件格式

配置文件是以.conf为后缀的文件,每一行对应一个配置,采用“Key=Value”的形式,注释可以使用“#"或者";",空行也是会被忽略的,如果配置两个相同的配置项,靠后的配置会覆盖前面的配置。

注意,在KEY名字可以使用 "/" 或 "." 作为分隔符。 如果第一个分隔符是 "/" , 那么其余的分隔符将保持原样; 如果第一个分隔符是 "." ,那么互换所有的 "/" 与 "."

例如:

"kernel.domainname=foo" 等价于 "kernel/domainname=foo" ,都会将 "foo" 写入
/proc/sys/kernel/domainname 参数中。 同样的,"
net.ipv4.conf.eno0/200.forwarding" 等价于 "
net/ipv4/conf/eno0.200/forwarding" , 都是指
/proc/sys/net/ipv4/conf/eno0.200/forwarding 参数。

sysctl.d/ 中的设置将在系统启动的早期被应用。

针对网络接口的配置, 则会在对应的网络接口出现的时候被应用, 具体说来就是 net.ipv4.conf.*, net.ipv6.conf.*, net.ipv4.neigh.*, net.ipv6.neigh.* 参数。

许多 sysctl 参数仅在加载相应的内核模块之后才可用。 因为内核模块是按需动态加载的 (例如在插入新硬件或启动网络时), 所以在系统启动早期运行的 systemd-sysctl.service无法设置那些依赖于特定内核模块的参数。

对于这些参数, 首选的方法是通过 udev规则来设置, 次选的方法是将这些模块添加到 modules-load.d中, 因为 modules-load.d中的模块会在运行 systemd-sysctl.service 前被无条件的静态加载。


例子

例 1. 设置内核YP域名

/etc/sysctl.d/domain-name.conf:

kernel.domainname=opcai.top

例 2. 利用udev规则设置动态内核模块的参数(方法一)

/etc/udev/rules.d/99-bridge.rules:

ACTION=="add", SUBSYSTEM=="module", KERNEL=="br_netfilter", \ 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

因为此方法在加载模块的同时设置模块的参数, 所以仅在加载 br_netfilter 模块之后才能过滤桥接包, 若不想过滤桥接包, 只要不加载 br_netfilter 模块即可。

例 3. 利用 modules-load.d 目录设置动态内核模块的参数(方法二)

/etc/modules-load.d/bridge.conf:

br_netfilter

/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

因为此方法总是无条件的加载 br_netfilter 模块, 并且总是无条件的设置模块的参数, 所以总是无条件的过滤桥接包,若不想过滤桥接包, 必须主动卸载 br_netfilter 模块。

相关推荐

Linux ntp时钟同步问题(linux ntp同步命令)

有时候,操作系统会报linux的ntp时钟错误。从时钟源同步时间超时。我查看了一下ntp的时钟源,发现执行ntpq-p显示超时。执行nslookup时钟服务器域名,发现可以正常解析。执行了n...

linux服务器同步利器Rsync全介绍(付脚本)

1、认识Rsync(remotesynchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。Rsync使用所谓的“Rsync算法”来使本地和远程两个主机之间的文件...

如何使用Rsync同步两个网站服务器的内容

本头条号每天坚持更新原创干货技术文章,欢迎关注本头条号"Linux学习教程",公众号名称“Linux入门学习教程"。如需学习视频,请复制以下信息到手机浏览器或电脑浏览器上:zc...

Linux TB级小文件同步备份解决方案

在某些电子档案存储的业务系统下,按照业务场景要求,需要将产生的所有电子影像资料永久存储,并支持备份;因为“钞能力”等原因,一般备份存储只有一个节点(即:一个备份存储服务器);这样就要求研发工程师,不...

CentOS7下使用Lsyncd实现文件实时同步

Lsyncd简单介绍Lsyncd使用文件系统事件接口(inotify或fsevents)来监视本地文件和目录的更改。Lsyncd在几秒钟内将这些文件事件整理核对后,然后生成一个或多个进程以将更...

如何手动同步Linux系统时间并与互联网时间保持同步?

在Linux系统中,正确的时间同步对于许多任务都是至关重要的。一些关键应用程序可能需要准确的时间戳才能正常工作,而一些安全功能也需要确保所有服务器的时间都是准确的。NTP服务可以自动同步系统时间和互...

Linux服务器Rsync定时同步一键化配置指南

1、主从服务器同时安装rsyncopenssh-clientaptupdate&&aptinstall-yrsyncopenssh-client2、主服务器安装好后输入以下命令生成密钥...

Linux系统如何使用NTPDATE命令设置时间同步

简介:咱们在使用Linux系统的时候,常常能发现用了一阵子之后,Linux系统的时间就对不上了。已经知道的情况是,安装Linux的时候选的时区是Asia/Shanghai,可这系统运行了一...

开源的Linux文件同步工具有哪些?(linux 文件夹 同步)

Linux系统之间经常需要文件同步,一个好的文件同步工具省时省力,这里介绍几款开源的Linux文件同步工具1.rsync:rsync是Linux上一个功能强大的命令行工具,可以在不同的服务器之间同...

Linux 系统使用 rsync + inotify 实现文件实时同步

Linux系统使用rsync+inotify实现文件实时同步简介inotify监控文件的变化后通知rsync进行文件的同步#配置免密登录ssh-keygen-trsaca...

Linux 远程数据同步工具详解(linux远程同步命令)

一、简介1认识Rsync(remotesynchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。Rsync使用所谓的“Rsync算法”来使本地和远程两个主机之...

构建基于 Linux 的 NTP 时间同步集群与时间安全防护实战指南

一、为什么时间同步对系统如此重要?在分布式系统、数据库复制、消息队列、审计日志、安全认证(如Kerberos)、容器编排等场景中,系统时间一致性是保障正确性与安全性的基础。一旦服务器间时间漂移,可能...

每日Linux学习:同步备份工具 rsync

rsync是一个用于高效同步文件和目录的工具。它通过仅传输变化的部分(增量传输)来节省时间和带宽,支持本地同步、远程同步(通过SSH),还能保留文件原有权限、时间戳等属性。本文通过几个常用的实例来...

Chromixium OS 1.0发布 基于Ubuntu发行版

Chromixium项目宣布chromixiumOS1发布,一款基于Ubuntu的Linux分支,chromixiumOS试图重新打造一款外观和感觉与ChromeOS相似的完...

iOS8.0.X~iOS8.1完美越狱!盘古团队出品

【巴士速递·移动情报站】最新消息,iOS8.1越狱了!!此次越狱依旧是iOS7时代我国的大神盘古团队带来的,而该次越狱支持最新的iPhone6、iPhone6Plus、iPadAir2和iPad...