一個完整的軟體系統大多數情況下是由多個進程共同協作進行的,即使它們在同一台伺服器上。所以,進程之間如何進行高效率的溝通至關重要。
php作為腳本語言,不像C /Java那樣進程常駐,所以它連接後端的服務都是使用短連線。
畫外音:有朋友說,可以用C寫擴充? (推薦學習:PHP影片教學)
上圖是典型場景,網站php部署在機器A上,快取memcache部署在機器B上,之間透過短連接通信,過程為:
(1) php建立tcp短連接;
(2) 依照memcache協定發送資料;
( 3) 接收memcache回傳的資料;
(4) php關閉tcp短連線;
在流量小時,上述流程沒有任何問題,當網站流量非常大的情況下,短連接可能會成為效能瓶頸,有什麼優化辦法嗎?
畫外音:建立連接,銷毀連接很耗時。
話鋒一轉,什麼是UNIX Domain Socket?
UNIX Domain Socket是一種IPC機制,它不需要經過網路協定棧,不需要打包拆包、計算校驗和、維護序號和應答等,只是將應用層資料從一個進程拷貝到另一個進程。
畫外音:IPC, Inter-Process Communication, 進程間通訊。
它可以用於同一台主機上兩個沒有親緣關係的進程,並且是全雙工的,提供可靠訊息傳遞(訊息不遺失、不重複、不錯亂)的IPC機制。
畫外音:親緣關係是指,父子過程或兄弟進程這種「特殊的」進程關係。
可以看到,UNIX Domain Socket的效率會遠高於tcp短連接,但它只能用於同一台主機間的進程通訊,而php應用和後端服務往往是部署在不同的機器上的,此時能否利用它來進行最佳化呢?
優化後的簡易架構圖如上:
(1) 在php應用伺服器上部署一個local-proxy;
(2) php與local-proxy之間使用UNIX Domain Socket來通訊;
(3) local-proxy與後端服務進行TCP長連線通訊;
#這樣就大大提升了通訊效率,免除了每次請求都要進行的建立與關閉tcp短連線的開銷
以上是php進程屬於長連接麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!