linux不常用内核参数说明

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;

转载于:https://blog.51cto.com/liuzhengwei521/2338512

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值