linux swap 分区 物理内存 内核参数 优化 笔试,记一次优化Linux服务器swap内存过高问题...

概述

今天收到zabbix告警,有点奇怪的是swap内存使用很高,但实际使用内存却不多,下面一起来看看吧:

5a5f8f96bba39e7bcf0c26547b55e9d3.png

1. 查看服务器内存使用情况

可以发现实际剩余内存还剩很多,但swap已经使用了90%

7d8019f3f1768b31e1899117755a0d0e.png

2. 查看占用swap过高的进程

正常情况下swap的使用应该是0,所以swap剩余小于80%时,我们便需要关注是哪个进程占用过高。

通过以下命令查看占用swap过高的进程:

for i in `cd /proc;ls |grep "^[0-9]"|awk ' $0>100'` ;do awk '/Swap:/{aa=a+$2}END{print '"$i"',a/1024"M"}' /proc/$i/smaps ;done |sort -k2nr

0655bf96c1ddea6706da27bc4ef6be95.png

3. 查看进程

检查pg数据库无异常,也没有任务在跑。

5ded686b9262aa874d1ad76d034f374f.png

4. 配置内核参数来减少swap的使用

如果内存够大,其实不必太多的使用 SWAP 分区, 可以通过修改 swappiness 的数值。swappiness=0的时候表示最大限度使用物理内存,然后才是 swap空间,swappiness=100的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。

在linux里面,默认设置swappiness这个值等于60。

现在一般1个G的内存可修改为10, 2个G的可改为5, 甚至是0。具体这样做:

--尽可能使用内存而不用swap

echo "vm.swappiness=1">>/etc/sysctl.conf

sysctl -p

--刷新SWAP

--刷新一次SWAP(将SWAP里的数据转储回内存,并清空SWAP里的数据)

swapoff -a && swapon -a

--清理缓存

sync

echo 3>/proc/sys/vm/drop_caches

5. 处理后结果

可以发现问题已解决。

a3e88770b195ee47ea9aee4ee2e31f23.png

【责任编辑:赵宁宁 TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值