workerman開發人員必須知道的幾個問題
1、Windows環境限制
在Windows系統下,workerman單個進程僅支持200+個連接。
在Windows系統下無法使用count參數設置多進程。
在Windows系統下無法使用status、stop、reload、restart等命令。
在Windows系統下無法守護進程,cmd視窗關掉後服務即停止。
在Windows系統下無法在一個文件中初始化多個監聽。
Linux系統無上面的限制,建議正式環境用Linux系統,開發環境可以選擇用Windows系統。
2、workerman不依賴Apache或者Nginx
workerman本身已經是一個類似Apache/Nginx的容器,只要PHP環境OK workerman就可以運行。
3、workerman是命令行啟動的
啟動方式類似Apache使用命令啟動(一般網頁空間無法使用workerman)。啟動界面類似下面
4、長連接必須加心跳
長連接必須加心跳,長連接必須加心跳,長連接必須加心跳,重要的話說三遍。
長連接長時間不通訊會被路由節點清理導致連接關閉。
workerman心跳說明、 gatewayWorker心跳說明
5、客戶端和服務端協議一定要對應才能通訊
這個是開發者非常常見的問題。例如客戶端是用websocket協議,服務端必須也是websocket協議(服務端new Worker('websocket://0.0.0.0...')
)才能連得上,才能通訊。
不要嘗試在瀏覽器地址欄訪問websocket協議端口,不要嘗試用webscoket協議訪問裸tcp協議端口,協議一定要對應。
這裡的原理類似如果你要和英國人交流,那麼要使用英語。如果要和日本人交流,那麼要使用日語。這裡的語言就類似與通訊協議,雙方(客戶端和服務端)必須使用相同的語言才能交流,否則無法通訊。
6、連接失敗可能的原因
剛開始使用workerman時很常見的一個問題是客戶端連接服務端失敗。 原因一般如下:
1、伺服器防火牆(包括雲伺服器安全組)阻止了連接 (50%機率是這個)
2、客戶端和服務端使用的協議不一致 (30%機率)
3、IP或者端口寫錯了 (15%的機率)
4、服務端沒啟動
7、不要使用exit die sleep語句
業務執行exit die語句會導致進程退出,並顯示WORKER EXIT UNEXPECTED錯誤。當然,進程退出了會立刻重啟一個新的進程繼續服務。如果需要返回,可以調用return。sleep語句會讓進程睡眠,睡眠過程中不會執行任何業務,框架也會停止運行,會導致該進程的所有客戶端請求都無法處理。
8、不要使用pcntl_fork函數
pcntl_fork
用來動態創建新的進程,如果在業務代碼中使用pcntl_fork
,它可能會產生無法回收孤兒進程,導致業務出現異常。業務中pcntl_fork
還會影響連接、消息、連接關閉、定時器等事件的處理,導致不可預知的異常。
9、業務代碼裡不要有死循環
業務代碼裡不要有死循環,否則會導致控制權無法交還給workerman框架,導致無法接收處理其他客戶端消息。
10、改代碼要重啟
workerman是常駐內存的框架,改代碼要重啟workerman才能看到新代碼的效果。
11、長連接應用建議用GatewayWorker框架
很多開發者使用workerman是要開發長連接應用,例如即時通訊、物聯網等,長連接應用建議直接使用GatewayWorker框架,它專門在workerman的基礎上再次封裝,做起長連接應用後臺更簡單、更易用。