Nginx服務(wù)器中的Socket切分是什么

本篇內(nèi)容介紹了“Nginx服務(wù)器中的Socket切分是什么”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)建站制作網(wǎng)站網(wǎng)頁找三站合一網(wǎng)站制作公司,專注于網(wǎng)頁設(shè)計,成都網(wǎng)站設(shè)計、成都網(wǎng)站制作,網(wǎng)站設(shè)計,企業(yè)網(wǎng)站搭建,網(wǎng)站開發(fā),建網(wǎng)站業(yè)務(wù),680元做網(wǎng)站,已為成百上千服務(wù),創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)將一如既往的為我們的客戶提供最優(yōu)質(zhì)的網(wǎng)站建設(shè)、網(wǎng)絡(luò)營銷推廣服務(wù)!

nginx發(fā)布的1.9.1版本引入了一個新的特性:允許使用so_reuseport套接字選項,該選項在許多操作系統(tǒng)的新版本中是可用的,包括dragonfly bsd和linux(內(nèi)核版本3.9及以后)。該套接字選項允許多個套接字監(jiān)聽同一ip和端口的組合。內(nèi)核能夠在這些套接字中對傳入的連接進行負載均衡。(對于nginx plus客戶,此功能將在年底發(fā)布的版本7中出現(xiàn))

so_reuseport選項有許多潛在的實際應(yīng)用。其他服務(wù)也可以使用它來簡單實現(xiàn)執(zhí)行中的滾動升級(nginx已經(jīng)通過支持了滾動升級)。對于nginx而言,啟用該選項可以減少在某些場景下的鎖競爭而改善性能。

如下圖描述,當(dāng)so_reuseport選項有效時,一個單獨的監(jiān)聽socket通知工作進程接入的連接,并且每個工作線程都試圖獲得連接。

Nginx服務(wù)器中的Socket切分是什么

當(dāng)so_reuseport選項啟用是,存在對每一個ip地址和端口綁定連接的多個socket監(jiān)聽器,每一個工作進程都可以分配一個。系統(tǒng)內(nèi)核決定哪一個有效的socket監(jiān)聽器(通過隱式的方式,給哪一個工作進程)獲得連接。這可以減少工作進程之間獲得新連接時的封鎖競爭(譯者注:工作進程請求獲得互斥資源加鎖之間的競爭),同時在多核系統(tǒng)可以提高性能。然而,這也意味著當(dāng)一個工作進程陷入阻塞操作時,阻塞影響的不僅是已經(jīng)接受連接的工作進程,也同時讓內(nèi)核發(fā)送連接請求計劃分配的工作進程因此變?yōu)樽枞?/p>

Nginx服務(wù)器中的Socket切分是什么

 設(shè)置共享socket

為了讓so_reuseport socket選項起作用,應(yīng)為http或tcp(流模式)通信選項內(nèi)的listen項直接引入新近的reuseport參數(shù),就像下例這樣:
 

復(fù)制代碼 代碼如下:


http {
     server {          listen 80 reuseport;
          server_name  localhost;
          ...
     }
}
 
stream {
     server {          listen 12345 reuseport;
          ...
     }
}

引用reuseport參數(shù)后,對引用的socket,accept_mutex參數(shù)將會無效,因為互斥量(mutex)對reuseport來說是多余的。對沒有使用reuseport的端口,設(shè)置accept_mutex仍然是有價值的。

reuseport的基準(zhǔn)性能測試

我在一個36核的aws實例運行基準(zhǔn)測試工具測試4個nginx 工作進程.為了減少網(wǎng)絡(luò)的影響,客戶端和nginx都運行在本地,并且讓nginx返回ok字符串而不是一個文件。我比較三種nginx配置:默認(等同于accept_mutex on ),accept_mutex off,和reuseport。如圖所示,reuseport的每秒請求是其余的兩到三倍,同時延遲和延遲標(biāo)準(zhǔn)差也是減少的。

Nginx服務(wù)器中的Socket切分是什么

 我又運行了另一個相關(guān)的性能測試——客戶端和nginx分別在不同的機器上且nginx返回一個html文件。如下表所示,用 reuseport 減少的延遲和之前的性能測試相似,延遲的標(biāo)準(zhǔn)差減少的更為顯著(接近十分之一)。其他結(jié)果(沒有顯示在表格中)同樣令人振奮。使用 reuseport ,負載被均勻分離到了worker進程。在默認條件下(等同于 accept_mutex on),一些worker分到了較高百分比的負載,而用 accept_mutex off 所有worker都受到了較高的負載。

復(fù)制代碼 代碼如下:

latency (ms)  latency stdev (ms)  cpu load
default  15.65  26.59  0.3
accept_mutex off  15.59  26.48  10
reuseport  12.35  3.15  0.3

在這些性能測試中,連接請求的速度是很高的,但是請求不需要大量的處理。其他的基本的測試應(yīng)該指出——當(dāng)應(yīng)用流量符合這種場景時 reuseport 也能大幅提高性能。(reuseport 參數(shù)在 mail 上下文環(huán)境下不能用在 listen 指令下,例如email,因為email流量一定不會匹配這種場景。)我們鼓勵你先測試而不是直接大規(guī)模應(yīng)用。

“Nginx服務(wù)器中的Socket切分是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

文章題目:Nginx服務(wù)器中的Socket切分是什么
瀏覽路徑:http://bm7419.com/article0/gosiio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、企業(yè)建站電子商務(wù)、軟件開發(fā)、外貿(mào)網(wǎng)站建設(shè)、微信公眾號

廣告

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

手機網(wǎng)站建設(shè)