当前位置:首页 > 知识转载 > 正文内容

转载-Linux下的Nginx内存泄露定位

转载自知乎”子期”的文章
链接:https://zhuanlan.zhihu.com/p/523110801


有同事报他的机器上nginx存在内存泄露,都吃了4G内存没法忍了,于是赶紧查一查。

问题定位

1、先top -u work 查看进程内存占用情况,确认确实是占了4G没法忍了(下图只是整理文档时补的示例)。

900×197 35.6 KB

2、ps -ef | grep nginx | grep -v grep | grep work

查看nginx进程确认是业务的nginx的某个worker子进程疑似存在内存泄露占了大量内存。

3、发现只有部分worker进程占用内容很大,并不是全部。cat error.log定位为什么不是worker进程都内存增大,只是个别worker进程内存占用很大?

900×401 89.6 KB

4、发现并不是那个子进程没有内存泄露,而是那个子进程频繁被kill,然后master又重启新的子进程。

通过:dmesg | grep pid ,查看系统日志。确认那些内存占用低的worker进程是被oom kill了,然后被master又重启新的子进程。

1080×140 26.6 KB

5、确定是指定进程内存泄露后,查看该进程的内存分配,定位泄露信息。

①.通过 pmap -x pid dump出该进程的内存分配,确认确实存在超大块内存分配。

900×760 95.7 KB

②.通过 cat /proc/pid/smaps查看内存段的具体起始位置。

900×525 39.9 KB

③.通过gdb dump出那段内存存储内容。

gdb -p 42102

dump binary memory ./memory2.log 0x7fa1d0b57000 0x7FA1D0B70000

900×378 83.7 KB

④.查看dump出的内容,发现是一个业务研发的nginx扩展存储的内容,确认是该扩展错在内容泄露。

  1. 问题明确后,具体修复问题就简单了,对应扩展修复问题后重新上线完成修复。

Linux进程内存分析常用工具命令

**top:**查看机器整体内存使用情况和各进程内存使用情况

**RES:**常驻内存,一般比较关心这个

**SHR:**共享内存

**VIRT:**虚拟内存

**DATA:**数据占用内存

**pmap:**pmap -x pid dump 进程的内存分配情况

**mtrace:**可以跟踪记录进程的内存分配

**gdb -p pid:**连接到进程

**cat /proc/pid/smaps:**查看内存块具体开始结束位置

**dump binary memory ./out.log 0x7fa1d0b57000 0x7FA1D0B70000:**dump出指定位置存储的内容

参考文献

https://javawind.net/p131

简书


扫描二维码推送至手机访问。

版权声明:本文由个人博客发布,如需转载请注明出处。

本文链接:https://opszzfwordpress.club/post/59.html

分享给朋友:

“转载-Linux下的Nginx内存泄露定位” 的相关文章

转载-shell编程100例(附PDF下载)

转自开源Linux的文章https://zhuanlan.zhihu.com/p/509956726...

转载-字节一面:服务端挂了,客户端的 TCP 连接还在吗?

转载-字节一面:服务端挂了,客户端的 TCP 连接还在吗?

版权声明:本文为CSDN博主「肥肥技术宅」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附...

转载-什么是LVM

转载-什么是LVM

作者:平凡人笔记链接:https://www.zhihu.com/question/35620754...

转载-Linux 运维一天的工作时间是如何度过的?

作者:地球的外星人君链接:https://www.zhihu.com/question/202611...

转载-Linux下的Nginx内存泄露定位

转载-Linux下的Nginx内存泄露定位

转载自知乎”子期”的文章链接:https://zhuanlan.zhihu.com/p/523110...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。