停止失敗

現象:

運行 php start.php stop 提示 stop fail

第一種可能性

前提是以debug方式啟動的workerman,開發者在終端按了ctrl z給workerman發送了SIGSTOP信號,導致workerman進入後臺並掛起(暫停),所以無法響應stop命令(SIGINT信號)。

解決:
在啟動workerman的終端輸入fg(發送SIGCONT信號)然後回車,將workerman切回前臺運行,按ctrl c(發送SIGINT信號)停止workerman。

如果無法停止,嘗試運行以下兩條命令

killall -9 php
ps aux|grep -i workerman|awk '{print $2}'|xargs kill -9

第二種可能性

運行stop的用戶和workerman啟動用戶不一致,即stop用戶沒有權限停止workerman。

解決:
切換到啟動workerman的用戶,或者用權限更高的用戶停止workerman。

第三種可能性

保存workerman主進程pid文件被刪除,導致腳本找不到pid進程,導致停止失敗。

解決:
將pid文件保存到安全的位置,參見手冊Worker::$pidFile

第四種可能性

workerman主進程pid文件對應的進程不是workerman進程。

解決:
打開workerman的主進程的pid文件查看主進程pid,pid文件默認在Workerman平行的目錄裡。運行命令 ps aux | grep 主進程pid 查看對應的進程是否是Workerman進程,如果不是,可能是伺服器重啟過,導致workerman保存的pid是過期的pid,而這個pid剛好被其它進程使用,導致停止失敗。如果是這種情況,將pid文件刪除即可。

第五種可能性

安裝了grpc擴展,但沒有給grpc擴展設置相應的環境變量,啟動後會多fork出一個掛載進程,停止時導致失敗。