性能文章>使用Top_X插件排查内存过载问题>

使用Top_X插件排查内存过载问题原创

1年前
1469204

Top命令是Linux 系统下常用的监控工具,用于实时获取进程级别的 CPU 或内存使用情况。

XPocket中的Top_X为Linux Top的增强版,可以显示CPU占用率/负载,CPU及内存进程使用的list。它对于繁杂的top命令输出进行了功能的拆分和整理,更加清晰易用,支持管道化,尤其可以直接拿到top进程或线程tid,pid; mem_s命令增加了按照进程swap大小占用排序增强了原有top功能。

下面我们模拟一机器内存泄漏使用了大量物理内存导致物理内存飙升的情况:

#include <stdio.h>


int fff()
{
    int i = 0;
    while(1)
    {
	sleep(1);
        void *m = malloc(1024*1024);
        memset(m,0,1024*1024);   // 不用memset这么多,只需要memset每个page的第一个字节偷懒了
        i++;
        printf("size = %d M\n", i);
        if( (i%1000 == 0) && (i/1000 != 0))
        {
            printf("size = %d M, sleep 30\n", i );
            sleep(30);     //多等待下 防止虚拟机swap占
 
        }

    }
    return 0;

}

int ddd()
{
    fff();
    return 0;
}

int main()
{
    ddd();
    return 0;
}

初始状态下内存空闲:
图片4.png

运行上述程序大量使用物理内存,Linux内存紧张, 模拟内存泄漏,触发系统swapper进程,测试可以观察到swap 空间被占用:
图片5.png

使用top_x插件看一下具体信息发现很多进程的内存被swap出去:
图片6.png

说明内存已经比较紧张了,通过top_x mem_r 命令查看下哪个进程占用的物理内存最多:
图片7.png

可以看到我们的useallmem+ 占用的物理内存高达 5.7g , 超过了内存总量的 74.9%之多。

Top_X插件下载地址:https://plugin.xpocket.perfma.com/plugin/65
XPocket下载地址:
https://xpocket.perfma.com/docs/download/

点赞收藏
小子z
请先登录,感受更多精彩内容
快去登录吧,你将获得
  • 浏览更多精彩评论
  • 和开发者讨论交流,共同进步

为你推荐

聊聊ThreadLocal的八个关键知识点

聊聊ThreadLocal的八个关键知识点

C++内存管理中内存泄漏产生的原因和解决办法

C++内存管理中内存泄漏产生的原因和解决办法

【译】一次交易类场景CPU飙升100%的故障排除案例

【译】一次交易类场景CPU飙升100%的故障排除案例

【全网首发】从 Linux 内核角度探秘 JDK NIO 文件读写本质

【全网首发】从 Linux 内核角度探秘 JDK NIO 文件读写本质

嵌入式linux-CPU性能优化小记

嵌入式linux-CPU性能优化小记

平均负载与 CPU 使用率,到底有啥区别?

平均负载与 CPU 使用率,到底有啥区别?

4
0