Linux机器内核参数理解(二)

一、vm.swappiness

vm.swappiness的值的大小对如何使用swap分区是有着很大的联系的。swappiness=0的时候表示最大限度使用物理内存,然后才是 swap空间,swappiness=100的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。linux的基本默认设置为60,也就是说,你的内存在使用到100-60=40%的时候,就开始出现有交换分区的使用。大家知道,内存的速度会比磁盘快很多,这样子会加大系统io,同时造的成大量页的换进换出,严重影响系统的性能,所以我们在操作系统层面,要尽可能使用内存,对该参数进行调整,一般sysctl vm.swappiness=10。
#查看
$ cat /proc/sys/vm/swappiness
60

二、vm.dirty_background_bytes & vm.dirty_background_ratio

vm.dirty_background_bytes: Contains the amount of dirty memory at which the background kernel flusher threads will start writeback. 当脏页所占的内存数量超过dirty_background_bytes时,内核的pdflush线程开始回写脏页。
vm.dirty_background_ratio: 默认值10,当脏页所占的百分比(相对于所有可用内存,即空闲内存页+可回收内存页)达到dirty_background_ratio时内核的pdflush线程开始回写脏页。增大会使用更多内存用于缓冲,可以提高系统的读写性能。当需要持续、恒定的写入场合时,应该降低该数值。Contains, as a percentage of total available memory that contains free pages and reclaimable pages, the number of pages at which the background kernel flusher threads will start writing out dirty data.
#查看
$ cat /proc/sys/vm/dirty_background_bytes
409600000
$ cat /proc/sys/vm/dirty_background_ratio
0

三、vm.dirty_bytes & vm.dirty_ratio

vm.dirty_bytes: 当脏页所占的内存数量达到dirty_bytes时,执行磁盘写操作的进程自己开始回写脏数据 .Contains the amount of dirty memory at which a process generating disk writes will itself start writeback.
vm.dirty_ratio: 当脏页所占的百分比(相对于所有可用内存,即空闲内存页+可回收内存页)达到dirty_ratio时,进程会自己开始回写脏数据。增大会使用更多系统内存用于缓冲,可以提高系统的读写性能。当需要持续、恒定的写入场合时,应该降低该数值。Contains, as a percentage of total available memory that contains free pages and reclaimable pages, the number of pages at which a process which is
generating disk writes will itself start writing out dirty data.
​
#重点
dirty_ratio是属于强制性的回写,也就是说当一个内存区的脏页达到这个比例时就会触发内核内存管理把脏页强制回写的流程,但dirty_background_ratio是属于软性的行为,因为这是透过pdflush内核线程进行的流程,可以在后台执行对这些脏页面回写,并不会因此影响到当下正在执行中的过程。 所以看Linux内核中预设的比例是脏页达到5%的比例时就会先透过pdflush内核线程进行回写,当脏页达到10%比例时,就等于是一个很严重的状况,此时就会在平衡脏页面流程中触发强制的回写,让系统可以回复到原本预设合理的状态。
#查看
$ cat /proc/sys/vm/dirty_bytes
0
$ cat /proc/sys/vm/dirty_ratio
80

四、vm.dirty_expire_centisecs & vm.dirty_writeback_centisecs

dirty_expire_centisecs:默认值:2999。参数意义:用来指定内存中数据是多长时间才算脏(dirty)数据。指定的值是按100算做一秒计算。只有当超过这个值后,才会触发内核进程pdflush将dirty数据写到磁盘。
dirty_writeback_centisecs:默认值:499.这个参数会触发pdflush回写进程定期唤醒,并将old数据写到磁盘。每次的唤醒的间隔,是以数字100算做1秒。如果将这项值设为500就相当5秒唤醒pdflush进程。如果将这项值设为0就表示完全禁止定期回写数据。
#查看
$ cat /proc/sys/vm/dirty_expire_centisecs
6000
$ cat /proc/sys/vm/dirty_writeback_centisecs
50

五、vm.overcommit_memory & vm.overcommit_ratio

它是 内存分配策略
可选值:0、1、2。
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存
​
Linux对大部分申请内存的请求都回复"yes",以便能跑更多更大的程序。因为申请内存后,并不会马上使用内存。这种技术叫做Overcommit。当linux发现内存不足时,会发生OOM killer(OOM=out-of-memory)。它会选择杀死一些进程(用户态进程,不是内核线程),以便释放内存。
当oom-killer发生时,linux会选择杀死哪些进程?选择进程的函数是oom_badness函数(在mm/oom_kill.c中),该函数会计算每个进程的点数(0~1000)。点数越高,这个进程越有可能被杀死。每个进程的点数跟oom_score_adj有关,而且oom_score_adj可以被设置(-1000最低,1000最高)。
​
​
overcommit_ratio:当 overcomit_memory= 2时,该参数有效,这个参数决定了内存分配上限,
上限的计算公式:物理内存 * overcommit_ratio  + swap大小
​
#查看
$ cat /proc/sys/vm/overcommit_memory
2
$ cat /proc/sys/vm/overcommit_ratio
83

转载于:https://my.oschina.net/207miner/blog/2996144

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值