1、参数介绍:
[root@ecs-262232 ~]# sysctl -a| grep dirty
vm.dirty_background_bytes = 0
vm.dirty_background_ratio = 10
vm.dirty_bytes = 0
vm.dirty_ratio = 30
vm.dirty_expire_centisecs = 3000
vm.dirty_writeback_centisecs = 500
vm.dirty_background_ratio:这个参数指定了当文件系统缓存脏页数量到达系统内存百分之多少时就会触发pdflush/flush/kdmflush等后台回写进程运行,将一定缓存的脏页刷入外存。
vm.dirty_ratio:是绝对的脏数据限制,内存里的脏数据百分比不能超过这个值。如果脏数据超过这个数量,新的IO请求将会被阻挡,直到脏数据写进磁盘。这是造成IO卡顿的的主要原因,但这也是保证内存不会存在过量脏数据的保护机制。
vm.dirty_background_byts和vm.dirty_back_bytes: 指定这些参数的另一种方法。
vm.dirty_expire_centisecs:指定脏数据的存活时间,当pdflush/flush/kdmflush进行起来时,它会检查是否有数据超过这个时限,如果有则会把它异步写到磁盘中。
vm.dirty_writeback_centisecs:指定多长时间pdflush/flush/kdmflush会起来一次。
2、应用场景:
应用1:减少缓存
在很多情况下,我们有快速的磁盘子系统,它们有自己的大电池支持的NVRAM缓存,所以将东西保存在系统页面缓存中是有风险的。让我们尝试以更及时的方式向磁盘发送IO,并减少本地操作系统“陷入困境”的机会。减小/etc/sysctl.conf中的vm.dirty_background_ratio和vm.dirty_ratio的值,并执行sysctl -p(重新加载)。但不建议设置这些参数为0,一些后台I/O可以很好地将应用程序性能与磁盘阵列在SAN(“峰值”)上的较短时间的较高延迟解耦。
vm.dirty_background_ratio = 5
vm.dirty_ratio = 10
应用2:增加缓存
在某些情况下,显著提高缓存对性能有积极作用。这种时候,Linux客户机上包含的数据不是关键的,可能会丢失,而且应用程序还会重复的写入相同文件。理论上,通过允许内存中存在更多的脏页,你将在缓存中一遍又一遍的重写相同的块,只需要每隔一段时间实际向磁盘写一次。
vm.dirty_background_ratio = 50
vm.dirty_ratio = 80
有时候还会提高 vm.dirty_expire_centisecs允许脏数据更长时间停留。除了增加数据丢失的风险之外,如果缓存已满并需要同步,还有长时间Io卡顿风险。
应用3:增加都用
有时候系统需要应对突如其来的高峰数据,他可能会拖延磁盘。比如说:每小时或者午夜进行处理作业、在Raspberry Pi上写SD卡等等。这种情况下,我们可以允许大量的写I/O存储在缓存中,这样后台刷新操作就可以慢慢处理它:
vm.dirty_background_ratio = 5
vm.dirty_ratio = 80
这个时候,系统后台进程在脏数据达到5%时就开始异步清理,但在80%之前系统不会强制同步写磁盘。再次基础上,调整RAM和vm.dirty_ratio就可以缓存所有写的数据,但磁盘上的数据也会有一定风险。
3、如何修改:
临时生效方法:
echo 5 > /proc/sys/vm/dirty_background_ratio
echo 10 > /proc/sys/vm/dirty_ratio
或者
sysctl -w vm.dirty_background_ratio=5
sysctl -w vm.dirty_ratio=10
永久生效方法:
echo "vm.dirty_background_ratio=5" >> /etc/sysctl.conf
echo "vm.dirty_ratio=10" >> /etc/sysctl.conf
sysctl -p /etc/sysctl.comf
4、手动刷新:
echo 1 > /proc/sys/vm/drop_caches //释放页缓存
echo 2 > /proc/sys/vm/drop_caches //释放slab cache中的可回收部分(dentries和inodes)
echo 3 > /proc/sys/vm/drop_caches //以上全部
参考: