先用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代码中调试输出,看看耗时操作在哪,建议将耗时操作放在消息队列中异步操作。
网友回复