宝塔面板负载状态显示100%
接着使用top命令查看了一下,发现cpu利用率很低,load却很高
通过使用 ps -axjf命令查看是否存在D状态进程
D 状态是指不可中断的睡眠状态,该状态的进程无法被 kill,也无法自行退出,只能通过恢复其依赖的资源或者重启系统来解决。
通过排查,发现存在D状态进程
如果发现没有D状态
1、需要打印出线程信息来分析,使用
jstack -l pid > jstack.log 如jstack -l 14 > jstack.log
2、然后使用
top -Hp pid 查出最占cpu的线程 如top -Hp 14
3、使用
printf “%x\n” pid 得到最耗时的PID需要转换成16进制4、将得到的16进制值在 jstack.log中搜索找到线程信息
最后根据实际情况来解决
查看是否是PHP-fpm的进程数过多
首先使用 free -m 指令查看当前服务器执行状况:
可以看到我的内存消耗不多,也能看到我是16G内存
然后再用 top 命令 m 参数 查看内存情况
再使用:ps auxw|head -1;ps auxw|sort -rn -k4|head -40 查看消耗内存最多的前40个进程
查看通过命令查看服务器上一共开了多少的 php-cgi 进程:
ps -fe |grep php-fpm|grep pool|wc -l
查看已经有多少个php-cgi进程用来处理tcp请求:
netstat -anp|grep php-fpm|grep tcp|grep pool|wc -l
设置PHP-FPM的进程数:vi /etc/php-fpm.d/www.conf(根据实际情况变化)找到 pm.max_children 字段,设置一个合理的值,比之前的小(从200改到50)
pm.max_spare_servers : 该值表示保证空闲进程数最大值,如果空闲进程大于此值,此进行清理 pm.min_spare_servers : 保证空闲进程数最小值,如果空闲进程小于此值,则创建新的子进程;
这两个值均不能不能大于 pm.max_children 值,通常设置 pm.max_spare_servers 值为 pm.max_children 值的60%-80%。
正常情况下,一个php–fpm占用内存20~30M
3.进程跟踪
1.使用 top 找出CPU最高的进程pid
2.strace -p PID(进程数) 来跟踪进程
3. ll /proc/PID/fd 来查看该进程在处理哪些文件
最后修改对应代码