sysctl命令被用于在内核运行时动态地修改内核的运行参数,可用的内核参数在目录/proc/sys
中。它包含一些TCP/ip堆栈和虚拟内存系统的高级选项,用sysctl可以读取设置超过五百个系统变量。
sysctl命令
用法:
sysctl [options] [variable[=value] …]
常用选项:
-n:打印时只打印值,不打印参数名称;
-e:忽略未知关键字错误;
-N:打印时只打印参数名称,不打印值;
-w:设置参数的值(不过好像不加这个选项也可以直接设置);
-p:从配置文件“/etc/sysctl.conf”加载内核参数设置;
-a:打印所有内核参数变量;
-A:以表格方式打印所有内核参数变量。
示例
1、 设置socket接收缓冲最大值(rmem_max)为212992字节
sudo sysctl -w net.core.rmem_max=212992
2、查看socket接收缓冲最大值(rmem_max)
sysctl net.core.rmem_max
sysctl可以设置查看的内核参数都在目录/proc/sys
中,每个文件都记录了一个参数,sysctl命令中其实也记录了参数的相对路径,只要将 . 换成 / 就是文件路径,比如记录net.core.rmem_max的文件就是/proc/sys/net/core/rmem_max
,所以也可以直接查看文件内容来读取参数的值
cat /proc/sys/net/core/rmem_max
如果不知道参数路径也可以这么做:
sysctl -a | grep rmem_max
配置sysctl
编辑此文件vi /etc/sysctl.conf
如果该文件为空,则输入以下内容,否则请根据情况自己做调整(复制自http://man.linuxde.net/sysctl):
# Controls source route verification
# Default should work for all interfaces
net.ipv4.conf.default.rp_filter = 1
# net.ipv4.conf.all.rp_filter = 1
# net.ipv4.conf.lo.rp_filter = 1
# net.ipv4.conf.eth0.rp_filter = 1
# Disables IP source routing
# Default should work for all interfaces
net.ipv4.conf.default