linux不常用内核参数说明
at 2年前 ca Linux pv 645 by touch
1.net.ipv4.ip_nonlocal_bind
net.ipv4.ip_nonlocal_bind:此参数表示是否允许服务绑定一个本机不存在的IP地址; 使用场景:有些服务需要依赖一个vip才能启动,但是此vip不在本机上,当vip飘移到本机上时才存在;但是服务又需要提前启动,例如haproxy,nginx等代理需要绑定vip时; 0:默认值,表示不允许服务绑定一个本机不存的地址 1:表示允许服务绑定一个本机不存在的地址
2.vm.min_free_kbytes
保留给内核使用的; 此参数的默认值为67584,即64M; 当到达min,系统会启动 kswapd 进行内存回收; 此值不宜设置过大,否则会造成kswapd进程持续运行,造成服务器故障;
3.vm.overcommit_memory
vm.overcommit_memory:表示系统允许内存的分配情况 0:默认值; 表示内核将检查是否有足够的可用内存供应用进程使用; 如果有足够的可用内存,内存申请允许; 否则,内存申请失败,并把错误返回给应用进程。 1:表示内核允许分配所有的物理内存,而不管当前的内存状态如何。redis要把此参数设为1; 2: 表示允许分配的内存为:物理内存*vm.overcommit_ratio+交换空间; 与参数vm.overcommit_ratio结合使用; 查看系统中可提交的内存和已经申请的内存: 执行命令:cat /proc/meminfo | awk '{print $1,$2/1024 " Mb"}' | grep "Commit" CommitLimit: 7934.45 Mb Committed_AS: 581.512 Mb CommitLimit:表示系统可分配的内存 Committed_AS:表示系统已经分配的内存
4.vm.overcommit_ratio
当overcommit_memory=2的时候,它一般是代表的是系统中物理内存的百分比; 默认值为:50 如:此值为50,系统内存为8G,swap为4G;则总的可分配内存为:4G + 8G*0.5 = 8G
5.kernel.msgmax
进程间的通信需要依靠内核来进行管理;是通过消息列队来传递消息; 以字节为单位,规定消息的单大值; 默认为65536,即64k; 此值不能超过kernel.msgmnb的值,msgmnb限定了消息队列的最大值;
6.kernel.msgmnb
以字节为单位,规定了一个消息队列的最大值; 默认值为:65536,即64k;
7.kernel.mni
指定消息队列的最大个数;
8.kernel.shmall
以**页**为单位,控制共享内存总量;Linux一个内存页大小为4kb;
9.kernel.shmmax
定义单个共享内存段的最大值; shmmax 设置应该足够大,设置的过低可能会导致需要创建多个共享内存段;
10.kernel.shmmni
定义共享内存段的个数,默认为4096;
版权声明
本文仅代表作者观点,不代表码农殇立场。
本文系作者授权码农殇发表,未经许可,不得转载。
已有0条评论