首頁 >後端開發 >PHP問題 >php進程屬於長連接麼

php進程屬於長連接麼

(*-*)浩
(*-*)浩原創
2019-10-21 11:09:502296瀏覽

一個完整的軟體系統大多數情況下是由多個進程共同協作進行的,即使它們在同一台伺服器上。所以,進程之間如何進行高效率的溝通至關重要。

php進程屬於長連接麼

php作為腳本語言,不像C /Java那樣進程常駐,所以它連接後端的服務都是使用短連線。

畫外音:有朋友說,可以用C寫擴充? (推薦學習:PHP影片教學

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應用和後端服務往往是部署在不同的機器上的,此時能否利用它來進行最佳化呢?

php進程屬於長連接麼

優化後的簡易架構圖如上:

(1) 在php應用伺服器上部署一個local-proxy;

(2) php與local-proxy之間使用UNIX Domain Socket來通訊;

(3) local-proxy與後端服務進行TCP長連線通訊;

#這樣就大大提升了通訊效率,免除了每次請求都要進行的建立與關閉tcp短連線的開銷

以上是php進程屬於長連接麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn