日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

相對于Apache的同步IO模型,Nginx由于采用了NIO的緣故,性能上碾壓前者。Nginx是輕量級的,占用的系統(tǒng)資源更少,天然支持高并發(fā)。

今天我們就簡單的討論一下nginx的線程模型。注意不是進(jìn)程模型哦。

nginx的IO模型,大家應(yīng)該都有所了解。簡單而言,就是一個(gè)master進(jìn)程和多個(gè)worker進(jìn)程(進(jìn)程數(shù)由配置決定);master進(jìn)程負(fù)責(zé)accept請求并隊(duì)列化,最后轉(zhuǎn)發(fā)給worker進(jìn)程并由其進(jìn)行請求處理和響應(yīng)的整個(gè)過程。

nginx是以多進(jìn)程模式運(yùn)行的。nginx在1.7.11版本提供了多線程特性(multi-threading),不過這個(gè)多線程僅用在aio模型中對本地文件的操作上,出發(fā)點(diǎn)就是以非阻塞模式,來提高文件IO的效率和并發(fā)能力。

所以這個(gè)多線程,并不是nginx通過多線程的方式處理proxy request(這部分是通過epoll模式),而是用來處理本地的一些靜態(tài)文件。

這里涉及到幾個(gè)基本指令:sendfile、aio和directio,它們均與本地文件的操作有關(guān),接下來我們分別看看它的意義。

sendfile

這個(gè)指令與系統(tǒng)函數(shù)sendfile()具有相同的語義,sendfile的目的就是提高本地文件通過socket發(fā)送的效率。官方的博客介紹了如何利用nginx 線程池aio,實(shí)現(xiàn)9倍的性能。

它還有一個(gè)比較好記的名稱,叫做零拷貝。那與傳統(tǒng)的文件讀取然后發(fā)送到網(wǎng)絡(luò)上,有什么區(qū)別呢?

磁盤、網(wǎng)絡(luò)驅(qū)動(dòng)器、內(nèi)存是三種不同的傳輸介質(zhì),如果從本地讀取一個(gè)文件并通過socket發(fā)送出去,通常情況下是進(jìn)過如下幾個(gè)步驟:

  • 1)磁盤驅(qū)動(dòng)器從根據(jù)CPU的調(diào)度,從磁盤讀取一定長度(chunk)的字節(jié)數(shù)據(jù)
  • 2)字節(jié)數(shù)據(jù)copy到內(nèi)核內(nèi)存中
  • 3)將內(nèi)核內(nèi)存中的數(shù)據(jù)copy到進(jìn)程工作區(qū)內(nèi)存
  • 4)進(jìn)程通過socket將數(shù)據(jù)copy到網(wǎng)絡(luò)驅(qū)動(dòng)器緩存, 并通過相應(yīng)的傳輸協(xié)議發(fā)送出去。

可以看到,數(shù)據(jù)的發(fā)送過程涉及到多次copy,這受限于計(jì)算機(jī)系統(tǒng)的設(shè)計(jì)問題。

sendfile的主要出發(fā)點(diǎn),就是要減少數(shù)據(jù)的copy以提高發(fā)送效率,sendfile是linux系統(tǒng)級的調(diào)用,socket可以通過DMA(直接內(nèi)存訪問)方式直接訪問文件數(shù)據(jù),并通過傳輸協(xié)議發(fā)送,減少了2次數(shù)據(jù)copy(磁盤到內(nèi)核,內(nèi)核到工作區(qū))。

sendfile_max_chunk參數(shù)用于限定每次sendfile()調(diào)用發(fā)送的最大數(shù)據(jù)尺寸,如果不限制大小的話,將會(huì)獨(dú)占整個(gè)worker進(jìn)程,默認(rèn)為“無限制”。這也太霸道了。

對于nginx而言,代理靜態(tài)本地的靜態(tài)文件資源(通常是小文件)將是非常高效的,建議對一些靜態(tài)文件比如html、圖片等,開啟此參數(shù)。

location /video {
    sendfile on;
    sendfile_max_chunk 128k;
    aio on;
}

directio

這個(gè)指令用于開啟對O_DIRECT標(biāo)記(BSD,linux)的使用,對應(yīng)directio()這個(gè)系統(tǒng)調(diào)用。

此參數(shù)是針對大文件而設(shè)定的,sendfile針對的是小文件。通過directio可以指定限定的尺寸大小,對于超過此size的文件,將會(huì)使用directio(而不再使用sendfile)。

根據(jù)directio的設(shè)計(jì)初衷,它具備sendfile的基本原理,只是不使用內(nèi)核cache,而是直接使用DMA,而且使用之后內(nèi)存cache(頁對齊部分)也將被釋放。

因此directio通常適用于大文件讀取,而且通常讀取頻率很低。因?yàn)閷τ诟哳l的讀取,它并不能提高效率(因?yàn)樗粫?huì)重用cache,而是每次都DMA)。由于存在性能權(quán)衡問題,此參數(shù)默認(rèn)為off。

location /video {
    sendfile on;
    directio 8m;
    aio on;
}

aio

談到aio模型,其實(shí)語義也基本相同,就是異步文件IO,nginx默認(rèn)關(guān)閉此特性,它需要在高版本的linux平臺(tái)上才支持(2.6.22+)。

在linux上,directio只能讀取基于512字節(jié)邊界對齊的blocks,文件結(jié)束的那些未對齊的block將使用阻塞模式讀取。

同樣,如果文件在開頭沒有對齊,整個(gè)文件都將阻塞式讀取。這里所謂的對齊,就是文件數(shù)據(jù)在內(nèi)存頁中的cache情況。

當(dāng)aio和sendfile都開啟時(shí),將會(huì)對那些size大于directio設(shè)定值的文件使用aio機(jī)制:即當(dāng)小于directio設(shè)定值的文件將直接使用sendfile(aio不參與)。

aio,簡單而言,就是使用多線程異步模式讀取較大的文件,以提高IO效率,但是事實(shí)上可能并沒有任何提高。因?yàn)榇笪募淖x取,并不能使用cache、而且本身也是耗時(shí)的,即使是多線程,對于request的等待時(shí)間也是無法預(yù)估的,特別是并發(fā)請求較高的時(shí)候。但是aio能夠提高IO的并發(fā)能力,這個(gè)是確定的。

默認(rèn)情況下,多線程模式是關(guān)閉的,我們需要通過--with-threads配置來開啟,此特性盡在支持epoll、kqueue的平臺(tái)上兼容。對于線程池的設(shè)置,我們可以通過thread_pool來聲明,并在aio指令中指定。

我們的配置文件近一步豐富了一些。

thread_pool default_pool threads=16;##main上下文
...
location /video {
    sendfile on;
    sendfile_max_chunk 128k;
    directio 8M;
    aio threads=default_pool;
}

當(dāng)線程池中所有的線程都處于busy狀態(tài),那么新的task請求將會(huì)加入到等待隊(duì)列。我們可以在thread_pool中使用max_queue參數(shù)來指定隊(duì)列的大小,默認(rèn)隊(duì)列大小為65536,當(dāng)隊(duì)列已滿后續(xù)的請求將會(huì)拋出error。

END

nginx官方宣稱使用多線程模式,在aio讀取文件場景下,性能有9倍的提升,但我還是對這個(gè)測試具有一定懷疑態(tài)度。

多線程 + aio在一定程度的確可以提高文件IO的讀取性能,但是對于大文件而言,這似乎并沒有想象的那么優(yōu)秀。這受制于linux平臺(tái)底層的本身特性,除非nginx自己對文件cache做了額外的操作。

到目前為止,xjjdog仍有以下建議(供參考):

  • 1)對于小文件的靜態(tài)代理,我們應(yīng)該開啟sendfile,這對性能的提升是顯著的。
  • 2)對于大文件讀?。ǖ皖l),我們可以嘗試開啟aio、directio,在提升并發(fā)能力的前提下,關(guān)注request的實(shí)際響應(yīng)效率;既然官方推薦這么用,我們可以報(bào)以嘗試的態(tài)度。
  • 3)對于高頻大文件讀取,aio、directio的性能或許提升并不顯著,但應(yīng)該不會(huì)降低性能。

分享到:
標(biāo)簽:線程 nginx
用戶無頭像

網(wǎng)友整理

注冊時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定