zoukankan      html  css  js  c++  java
  • 怎样查看哪些程序占用了swap空间

    最近有人问,我的系统swap快被耗尽了,可是却不知道哪些程序占用了swap,到处发帖问什么命令可以查看。其实linux系统目前并没有这样的命令(或许是有,但我孤陋寡闻不清楚),但是我们可以通过编写脚本来自己找出占用swap的程序。

    那么怎样编写这个脚本呢,首先、我们需要知道去哪查看进程占用资源的情况。每个进程都会在/proc下面生成一个以进程号为名字的目录,里面的各个文件就是其在内存中的映像。

    其中smaps这个文件,便记载了每个进程每个数据段占用内存的情况。

    如下是某占用swap的进程的smaps文件截图(部分):




    Swap: 后面的数字,就是该数据段占用的swap大小,我们只要把这个文件里所有出现的swap加起来,就是这个进程所占用的swap大小了。

    OK,下面开始写代码:


    点击(此处)折叠或打开

    1. #!/bin/bash
    2. ###############################################################################
    3. # 日期 : 2011-10-31
    4. # 作者 : xiaoxi227
    5. # Email : xiaoxi227@163.com
    6. # QQ : 543928910
    7. # 版本 : 1.0
    8. # 脚本功能 : 列出正在占用swap的进程。
    9. # 调用关系 :
    10. # 其他说明 :
    11. ###############################################################################
    12. echo -e "PID\t\tSwap\t\tProc_Name"
    13.  
    14. # 拿出/proc目录下所有以数字为名的目录(进程名是数字才是进程,其他如sys,net等存放的是其他信息)
    15. for pid in `ls -l /proc | grep ^d | awk '{ print $9 }'| grep -v [^0-9]`
    16. do
    17. # 让进程释放swap的方法只有一个:就是重启该进程。或者等其自动释放。
    18. # 如果进程会自动释放,那么我们就不会写脚本来找他了,找他都是因为他没有自动释放。
    19. # 所以我们要列出占用swap并需要重启的进程,但是init这个进程是系统里所有进程的祖先进程
    20. # 重启init进程意味着重启系统,这是万万不可以的,所以就不必检测他了,以免对系统造成影响。
    21. if [ $pid -eq 1 ];then continue;fi # Do not check init process
    22. # 判断改进程是否占用了swap
    23. grep -q "Swap" /proc/$pid/smaps 2>/dev/null
    24. if [ $? -eq 0 ];then # 如果占用了swap
    25. swap=$(grep Swap /proc/$pid/smaps \ # 占用swap的总大小(单位:KB)
    26. | gawk '{ sum+=$2;} END{ print sum }')
    27. proc_name=$(ps aux | grep -w "$pid" | grep -v grep \ # 进程名
    28. | awk '{ for(i=11;i<=NF;i++){ printf("%s ",$i); }}')
    29. if [ $swap -gt 0 ];then # 如果占用了swap则输出其信息
    30. echo -e "$pid\t${swap}\t$proc_name"
    31. fi
    32. fi
    33. done | sort -k2 -n | gawk -F'\t' '{ # 按占用swap的大小排序,再用awk实现单位转换。
    34. # 如:将1024KB转换成1M。将1048576KB转换成1G,以提高可读性。
    35. pid[NR]=$1;
    36. size[NR]=$2;
    37. name[NR]=$3;
    38. }
    39. END{
    40. for(id=1;id<=length(pid);id++)
    41. {
    42.     if(size[id]<1024)
    43.           printf("%-10s\t%15sKB\t%s\n",pid[id],size[id],name[id]);
    44.     else if(size[id]<1048576)
    45.           printf("%-10s\t%15.2fMB\t%s\n",pid[id],size[id]/1024,name[id]);
    46.     else
    47.   printf("%-10s\t%15.2fGB\t%s\n",pid[id],size[id]/1048576,name[id]);
    48. }
    49. }'

    本人在某台已占用swap的服务器执行的结果如下:


    图片有删减(为方便阅读)

    脚本执行结果一目了然,如果某程序占用了大量的swap,则重启该进程即可。否则时间长了,很可能会因为swap耗尽而导致系统死机。
  • 相关阅读:
    递归算法解析成树形结构
    Tomcat性能参数设置
    hibernate.cfg.xml 配置(摘录)
    OpenCms 集成外部Solr Server
    安装配置OPENCMS的Replication cluster(从)详细过程
    ruby 格式化当前日期时间
    Ruby 语法快速入门
    ruby condition
    配置 RAILS FOR JRUBY1.7.4
    我的权限系统设计实现MVC4 + WebAPI + EasyUI + Knockout(五)框架及Web项目的组件化
  • 原文地址:https://www.cnblogs.com/feihongwuhen/p/7169856.html
Copyright © 2011-2022 走看看