网站首页 > 技术教程 正文
有同事报他的机器上nginx存在内存泄露,都吃了4G内存没法忍了,于是赶紧查一查。
问题定位
1、先top -u work 查看进程内存占用情况,确认确实是占了4G没法忍了(下图只是整理文档时补的示例)。
2、ps -ef | grep nginx | grep -v grep | grep work
查看nginx进程确认是业务的nginx的某个worker子进程疑似存在内存泄露占了大量内存。
3、发现只有部分worker进程占用内容很大,并不是全部。cat error.log定位为什么不是worker进程都内存增大,只是个别worker进程内存占用很大?
4、发现并不是那个子进程没有内存泄露,而是那个子进程频繁被kill,然后master又重启新的子进程。
通过:dmesg | grep pid ,查看系统日志。确认那些内存占用低的worker进程是被oom kill了,然后被master又重启新的子进程。
5、确定是指定进程内存泄露后,查看该进程的内存分配,定位泄露信息。
①.通过 pmap -x pid dump出该进程的内存分配,确认确实存在超大块内存分配。
②.通过 cat /proc/pid/smaps查看内存段的具体起始位置。
③.通过gdb dump出那段内存存储内容。
gdb -p 42102
dump binary memory ./memory2.log 0x7fa1d0b57000 0x7FA1D0B70000
④.查看dump出的内容,发现是一个业务研发的nginx扩展存储的内容,确认是该扩展错在内容泄露。
- 问题明确后,具体修复问题就简单了,对应扩展修复问题后重新上线完成修复。
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://qrcode.ceba.ceshiren.com/link?name=article&project_id=qrcode&from=toutiao×tamp=1661965200&author=Muller
猜你喜欢
- 2024-09-16 系统优化之Nginx性能排查,常用日志分割
- 2024-09-16 nginx检查提示“unknown directive "stream" in /etc/*/nginx.conf”
- 2024-09-16 不会Nginx Ingress可观测,你还算的上运维工程师吗?
- 2024-09-16 解锁Nginx日志的宝藏:GoAccess—你的实时交互式Web日志分析神器
- 2024-09-16 linux查看nginx、apache、php、php-fpm、mysql及配置项所在目录
- 2024-09-16 查漏补缺!我再讲一遍Nginx,务必记住这10000字内容
- 2024-09-16 「查缺补漏」巩固你的Nginx知识体系
- 2024-09-16 在Linux环境中查看和分析Nginx服务器日志信息
- 2024-09-16 如何查看Nginx反向代理多台服务器
- 2024-09-16 14、Nginx-查看响应状态、替换响应内容
你 发表评论:
欢迎- 最近发表
-
- Linux新手必看:几种方法帮你查看CPU核心数量
- linux基础命令之lscpu命令(linux中ls命令的用法)
- Linux lscpu 命令使用详解(linux常用ls命令)
- 如何查询 Linux 中 CPU 的数量?这几个命令要知道!
- 在linux上怎么查看cpu信息(linux如何查看cpu信息)
- 查看 CPU 的命令和磁盘 IO 的命令
- 如何在CentOS7上改变网卡名(centos怎么改网卡名字)
- 网工必备Linux网络管理命令(网工必备linux网络管理命令是什么)
- Linux 网络命令知多少(linux 网络 命令)
- Linux通过命令行连接wifi的方式(linux命令行连接无线网)
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)