http://huoding.com/2012/11/08/198
Swappiness的迷失
实际上,当可用内存不足时,系统有两个选择:一个是通过SWAP来释放内存,另一个是删除Cache中的Page来释放内存。一个很常见的例子是:当拷贝大文件的时候,时常会发生SWAP现象。这是因为拷贝文件的时候,系统会把文件内容在Cache中按Page来缓存,此时一旦可用内存不足,系统便会倾向于通过SWAP来释放内存。
内核中的swappiness参数可以用来控制这种行为,缺省情况下,swappiness的值是60:
shell> sysctl -a | grep swappiness vm.swappiness = 60
它的含义是:如果系统需要内存,有百分之六十的概率执行SWAP。知道了这一点,我们很自然的会想到用下面的方法来降低执行SWAP的概率:
shell> echo "vm.swappiness = 0" >> /etc/sysctl.conf shell> sysctl -p
这样做的确可以降低执行SWAP的概率,但并不意味着永远不会执行SWAP。
理解Swappiness与内存管理
本文探讨了Linux内核中的swappiness参数如何影响内存管理,解释了系统在内存不足时的两种策略:SWAP和删除Cache中的Page。通过调整swappiness参数,可以降低执行SWAP操作的概率,但并非完全避免。
1048

被折叠的 条评论
为什么被折叠?



