当swap分区占用过大时一般我们有以下4个解决方法:
1、swap分区较小,恰好内存的 free>swap used ;刷新交换分区将交换分区的缓存转回到内存
2、swap used > 内存的free;这个时候刷新交换分区转回内存时:1.提示无法转换 2.服务器内存耗尽直接造成宕机
这时我们执行swap分区占用的进程脚本:swap_check.sh
列出/proc目录下所有以数字为名的目录(进程名是数字才是进程,其他如sys,net等存放的是其他信息)
,让进程释放swap的方法只有一个:就是重启该进程,或者等其自动释放。
3.有些系统在创建时分配交换分区较小,可以扩展swap分区,没有多余磁盘的情况下可以在磁盘上新建一个swap目录
4.有时我们发现内存free 有很大空间swap分区还是占用了,这时我们可以优化swap
vm.swappiness优化:
swappiness的值的大小对如何使用swap分区是有着很大的联系的。swappiness=0的时候表示最大限度使用物理内存,然后才是 swap空间,swappiness=100的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。linux的基本默认设置为60,具体如下:
60
也就是说,你的内存在使用到100-60=40%的时候,就开始出现有交换分区的使用。大家知道,内存的速度会比磁盘快很多,这样子会加大系统io,同时造的成大量页的换进换出,严重影响系统的性能,所以我们在操作系统层面,要尽可能使用内存,对该参数进行调整。
临时调整的方法如下,我们调成10:
10
这只是临时调整的方法,重启后会回到默认设置的
如果觉得我的文章对您有用,请点赞。您的支持将鼓励我继续创作!
赞0
添加新评论0 条评论