国产+高潮+在线,国产 av 仑乱内谢,www国产亚洲精品久久,51国产偷自视频区视频,成人午夜精品网站在线观看

在生產(chǎn)環(huán)境restart之后 程序沒有完全停止導致端口被占用

twobody

問題描述

在生產(chǎn)環(huán)境中 php start.php restart之后
Fatal error: Uncaught Exception: Address already in use in

程序代碼或配置

29403

重現(xiàn)問題的步驟

第一次的stopping的日志是正常輸出的,因為pid文件中的pid值和系統(tǒng)的對的上,然后看了下只stop了兩個pid,導致start的時候端口被占用了。
截圖
截圖

操作系統(tǒng)環(huán)境及workerman/webman等具體版本

這里寫具體的系統(tǒng)環(huán)境相關信息
php版本 8.1
系統(tǒng)是centos
本地mac運行沒這個問題

874 1 0
1個回答

walkor 打賞

出現(xiàn)這個問題一般是因為runtime下的pid文件和系統(tǒng)實際情況不一致導致的,
stop時會通過pid文件找到進程,然后停止。如果pid文件里的記錄值是錯的導致無法停止之前的進程,再次啟動時會報占用錯誤。

造成pid文件不一致的原因一般是將錯誤的將pid文件放到了代碼庫,或者上傳文件時上傳了本地的pid等原因。
另外如果有手動kill了workerman的主進程,子進程還存在,也會有此問題。

社區(qū)里反饋有一些擴展影響了php的行為例如grpc擴展沒有正確配置也會類似問題。

如果不是以上原因需要自己定位下,停止前cat下pid文件值,運行 ps auxf 看下進程樹,看下是否對應。stop后 ps auxf 看下進程樹是否正確。

  • 軟飯工程師 2024-01-11

    如果某些操作導致主進程被殺死,子進程還在運行,php start.php stop 提示no run,php start.php start 提示端口被占用,這種情況有什么比較好的辦法嗎,只能手動一個個把子進程殺死?

  • walkor 2024-01-11

    一個一個殺死

  • twobody 2024-01-12

    感謝回復,目前沒有再出現(xiàn)過

年代過于久遠,無法發(fā)表回答
??