记一次优化Linux服务器swap内存过高问题

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

概述

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

记一次优化Linux服务器swap内存过高问题

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

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

记一次优化Linux服务器swap内存过高问题

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

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

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

  1. 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 
记一次优化Linux服务器swap内存过高问题

3. 查看进程

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

记一次优化Linux服务器swap内存过高问题

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

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

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

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

  1. --尽可能使用内存而不用swap 
  2. echo "vm.swappiness=1">>/etc/sysctl.conf 
  3. sysctl -p 
  4.  
  5. --刷新SWAP 
  6. --刷新一次SWAP(将SWAP里的数据转储回内存,并清空SWAP里的数据) 
  7. swapoff -a && swapon -a 
  8.  
  9. --清理缓存 
  10. sync 
  11. echo 3> /proc/sys/vm/drop_caches 

5. 处理后结果

可以发现问题已解决。

记一次优化Linux服务器swap内存过高问题

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2019-08-01 15:05:22

2019-04-29 14:23:46

Java服务器CPU

2021-01-11 05:24:53

缓存服务器

2022-09-14 12:01:35

服务器入侵篡改,

2023-01-04 18:32:31

线上服务代码

2019-09-24 07:00:01

SQL Server服务器卡顿内存分配

2013-12-24 13:59:03

2022-02-08 17:17:27

内存泄漏排查

2021-10-14 10:53:20

数据库查询超时

2022-02-17 11:19:33

Kubernetes服务器运维

2019-06-11 09:23:38

2023-04-06 07:53:56

Redis连接问题K8s

2021-01-08 13:52:15

Consul微服务服务注册中心

2020-10-30 14:11:38

服务器SDK堆栈

2011-02-22 09:29:23

jQueryJavaScript

2013-12-23 09:38:11

2010-04-28 17:14:52

Google服务器

2018-11-13 10:44:23

Linux服务器双网卡网络

2021-05-13 08:51:20

GC问题排查

2021-03-12 15:08:23

服务器性能优化
点赞
收藏

51CTO技术栈公众号