+
95
-

回答

先用top命令找到占用cpu太高的进程id,或者可以通过ps命令来搜索php-fpm进程,在linux、centos命令行输入一下命令:

ps aux | grep 'php' | grep -v 'php-fpm'

再尝试用strace命令看下卡住的进程当前究竟在干什么:

sudo strace -p 13793

Process 13793 attached - interrupt to quit

还可以用netstat看下这个进程是否打开了什么端口:

 sudo netstat -tunpa | grep 13793

tcp 0 0 192.168.1.100:38019 192.168.1.101:3306 ESTABLISHED 13793/php
tcp 0 0 192.168.1.100:47107 192.168.1.102:6379 CLOSE_WAIT 13793/php

还可以对linux centos网络数据包抓包,可以通过抓包的操作来获取php与其他服务的网络通信数据包,命令如下:

tcpdump -i eth0 host 192.168.1.101 and port 3306 -w ~/mysql.cap

最后还可以在php代码中调试输出,看看耗时操作在哪,建议将耗时操作放在消息队列中异步操作。

网友回复

我知道答案,我要回答