php進(jìn)程屬不屬于長連接

這篇文章將為大家詳細(xì)講解有關(guān)php進(jìn)程屬不屬于長連接,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

10年積累的做網(wǎng)站、成都網(wǎng)站設(shè)計經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有源匯免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

一個完整的軟件系統(tǒng)大多數(shù)情況下是由多個進(jìn)程共同協(xié)作進(jìn)行的,哪怕它們在同一臺服務(wù)器上。所以,進(jìn)程之間如何進(jìn)行高效的通信至關(guān)重要。

php作為腳本語言,不像C++/Java那樣進(jìn)程常駐,所以它連接后端的服務(wù)都是使用短連接。

畫外音:有朋友說,可以用C寫擴(kuò)展?

php進(jìn)程屬不屬于長連接

上圖是一種典型場景,站點(diǎn)php部署在機(jī)器A上,緩存memcache部署在機(jī)器B上,之間通過短連接通信,過程為:

(1) php建立tcp短連接;

(2) 按照memcache協(xié)議發(fā)送數(shù)據(jù);

(3) 接收memcache返回的數(shù)據(jù);

(4) php關(guān)閉tcp短連接;

在流量小時,上述過程沒有任何問題,當(dāng)網(wǎng)站流量非常大的情況下,短連接可能會成為性能瓶頸,有什么優(yōu)化辦法嗎?

畫外音:建立連接,銷毀連接很耗時。

話鋒一轉(zhuǎn),什么是UNIX Domain Socket?

UNIX Domain Socket是一種IPC機(jī)制,它不需要經(jīng)過網(wǎng)絡(luò)協(xié)議棧,不需要打包拆包、計算校驗和、維護(hù)序號和應(yīng)答等,只是將應(yīng)用層數(shù)據(jù)從一個進(jìn)程拷貝到另一個進(jìn)程。

畫外音:IPC, Inter-Process Communication, 進(jìn)程間通信。

它可以用于同一臺主機(jī)上兩個沒有親緣關(guān)系的進(jìn)程,并且是全雙工的,提供可靠消息傳遞(消息不丟失、不重復(fù)、不錯亂)的IPC機(jī)制。

畫外音:親緣關(guān)系是指,父子進(jìn)程或者兄弟進(jìn)程這種“特殊的”進(jìn)程關(guān)系。

可以看到,UNIX Domain Socket的效率會遠(yuǎn)高于tcp短連接,但它只能用于同一臺主機(jī)間的進(jìn)程通訊,而php應(yīng)用和后端服務(wù)往往是部署在不同的機(jī)器上的,此時能否利用它來進(jìn)行優(yōu)化呢?

php進(jìn)程屬不屬于長連接

優(yōu)化后的簡易架構(gòu)圖如上:

(1) 在php應(yīng)用服務(wù)器上部署一個local-proxy;

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

(3) local-proxy與后端服務(wù)進(jìn)行TCP長連接通訊;

這樣就大大提升了通訊效率,免除了每次請求都要進(jìn)行的建立與關(guān)閉tcp短連接的開銷

關(guān)于php進(jìn)程屬不屬于長連接就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

網(wǎng)站名稱:php進(jìn)程屬不屬于長連接
當(dāng)前地址:http://muchs.cn/article34/pippse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)搜索引擎優(yōu)化、虛擬主機(jī)網(wǎng)站內(nèi)鏈、Google定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化