這篇文章將為大家詳細講解有關php進程屬不屬于長連接,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
一個完整的軟件系統大多數情況下是由多個進程共同協作進行的,哪怕它們在同一臺服務器上。所以,進程之間如何進行高效的通信至關重要。
php作為腳本語言,不像C++/Java那樣進程常駐,所以它連接后端的服務都是使用短連接。
畫外音:有朋友說,可以用C寫擴展?
上圖是一種典型場景,站點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進程屬不屬于長連接就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。