国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Nginx“線程池模式”探討;據說性能提高了9倍

網絡 通信技術
相對于Apache的同步IO模型,Nginx由于采用了NIO的緣故,性能上碾壓前者。Nginx是輕量級的,占用的系統資源更少,天然支持高并發。今天我們就簡單的討論一下nginx的線程模型。注意不是進程模型哦。

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

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

[[329977]]

nginx的IO模型,大家應該都有所了解。簡單而言,就是一個master進程和多個worker進程(進程數由配置決定);master進程負責accept請求并隊列化,最后轉發給worker進程并由其進行請求處理和響應的整個過程。

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

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

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

sendfile

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

它還有一個比較好記的名稱,叫做零拷貝。那與傳統的文件讀取然后發送到網絡上,有什么區別呢?

磁盤、網絡驅動器、內存是三種不同的傳輸介質,如果從本地讀取一個文件并通過socket發送出去,通常情況下是進過如下幾個步驟:

  • 磁盤驅動器從根據CPU的調度,從磁盤讀取一定長度(chunk)的字節數據
  • 字節數據copy到內核內存中
  • 將內核內存中的數據copy到進程工作區內存
  • 進程通過socket將數據copy到網絡驅動器緩存, 并通過相應的傳輸協議發送出去。

可以看到,數據的發送過程涉及到多次copy,這受限于計算機系統的設計問題。

sendfile的主要出發點,就是要減少數據的copy以提高發送效率,sendfile是linux系統級的調用,socket可以通過DMA(直接內存訪問)方式直接訪問文件數據,并通過傳輸協議發送,減少了2次數據copy(磁盤到內核,內核到工作區)。

sendfile_max_chunk參數用于限定每次sendfile()調用發送的最大數據尺寸,如果不限制大小的話,將會獨占整個worker進程,默認為“無限制”。這也太霸道了。

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

  1. location /video { 
  2.     sendfile on; 
  3.     sendfile_max_chunk 128k; 
  4.     aio on; 

directio

這個指令用于開啟對O_DIRECT標記(BSD,linux)的使用,對應directio()這個系統調用。

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

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

因此directio通常適用于大文件讀取,而且通常讀取頻率很低。因為對于高頻的讀取,它并不能提高效率(因為它不會重用cache,而是每次都DMA)。由于存在性能權衡問題,此參數默認為off。

  1. location /video { 
  2.     sendfile on; 
  3.     directio 8m; 
  4.     aio on; 

aio

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

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

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

當aio和sendfile都開啟時,將會對那些size大于directio設定值的文件使用aio機制:即當小于directio設定值的文件將直接使用sendfile(aio不參與)。

aio,簡單而言,就是使用多線程異步模式讀取較大的文件,以提高IO效率,但是事實上可能并沒有任何提高。因為大文件的讀取,并不能使用cache、而且本身也是耗時的,即使是多線程,對于request的等待時間也是無法預估的,特別是并發請求較高的時候。但是aio能夠提高IO的并發能力,這個是確定的。

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

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

  1. thread_pool default_pool threads=16;##main上下文 
  2. ... 
  3. location /video { 
  4.     sendfile on; 
  5.     sendfile_max_chunk 128k; 
  6.     directio 8M; 
  7.     aio threads=default_pool

當線程池中所有的線程都處于busy狀態,那么新的task請求將會加入到等待隊列。我們可以在thread_pool中使用max_queue參數來指定隊列的大小,默認隊列大小為65536,當隊列已滿后續的請求將會拋出error。

END

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

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

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

  • 對于小文件的靜態代理,我們應該開啟sendfile,這對性能的提升是顯著的。
  • 對于大文件讀取(低頻),我們可以嘗試開啟aio、directio,在提升并發能力的前提下,關注request的實際響應效率;既然官方推薦這么用,我們可以報以嘗試的態度。
  • 對于高頻大文件讀取,aio、directio的性能或許提升并不顯著,但應該不會降低性能。

 

責任編輯:趙寧寧 來源: 小姐姐味道
相關推薦

2020-06-11 08:05:47

nginx線程池數據

2024-05-11 09:24:15

性能Go團隊

2021-12-08 12:50:39

代碼MyBatisJava

2024-02-07 13:37:39

AWS系統應用程序

2020-02-25 16:51:34

Rust廣告攔截器瀏覽器

2020-08-21 10:59:10

微軟服務器運維

2019-06-21 08:39:23

SQLmysql索引

2021-07-28 14:35:09

代碼進度條前端

2024-07-12 11:44:39

2019-12-10 09:47:51

IaaS云計算物聯網

2021-09-01 17:53:29

iOS14數據

2020-12-24 19:29:08

PCIntel芯片

2023-12-26 17:18:13

darktable

2012-05-02 11:09:38

無線網絡數據傳輸

2012-05-02 12:39:31

無線網絡多跳無線網絡數據傳輸

2022-09-29 09:19:04

線程池并發線程

2024-08-07 08:51:20

Go優化開發

2017-05-31 15:36:59

5G頻譜傳感器

2023-05-22 07:27:08

AI
點贊
收藏

51CTO技術棧公眾號

中文字幕第5页| av美女在线| 男女裸体影院高潮| 中文字幕中文字幕一区三区| 91中文在线观看| 国产女人18毛片| 电影在线一区| 久久综合福利| 久99久在线| 亚洲激情文学| 日韩精选在线| 白白色亚洲国产精品| 日韩精品视频在线观看网址| 91久久一区二区| 亚洲风情在线资源站| 亚洲男同1069视频| **性色生活片久久毛片| 国产精品久久99| 国产精品私人自拍| 中文字幕一区二区三区在线观看 | 成人午夜免费电影| 国产黄人亚洲片| 国产成人精品1024| 成人免费毛片片v| 不卡欧美aaaaa| 337p粉嫩大胆噜噜噜噜噜91av| 91色乱码一区二区三区| 久久精品人人做人人综合| 国产视频在线观看一区二区三区| 国产清纯在线一区二区www| 国产精品美女久久久久久久| 中文字幕一区二区三区视频| 一区二区国产视频| 精品久久久中文| 欧美三级视频在线播放| 91精品国产综合久久久久久久| 精品国产污污免费网站入口| 亚洲欧美成人一区二区三区| 91视频九色网站| 91电影在线播放| av电影在线播放高清免费观看| 9l视频自拍九色9l视频成人| 亚洲男帅同性gay1069| 国产精品久久中文| 亚洲综合资源| 成年网站在线| а√中文在线8| 岛国片av在线| √天堂8资源中文在线| 最新中文字幕在线播放| 亚洲精品国产嫩草在线观看| 国产精品视频一区二区三区综合| 高潮久久久久久久久久久久久久| 三级精品视频| 中文在线播放一区二区| 亚洲欧美成人| 激情综合亚洲精品| 91热门视频在线观看| 综合中文字幕亚洲| 色欧美乱欧美15图片| 亚洲成人免费在线视频| 精品精品国产国产自在线| 91成人在线播放| 亚洲一区亚洲二区| 亚洲精品在线观看免费| 亚洲乱码中文字幕久久孕妇黑人| 黄色网址三级| 日本中文字幕在线2020| 日韩不卡免费高清视频| 日韩精品亚洲aⅴ在线影院| 一二三区不卡| 久久9热精品视频| 国产蜜臀av在线一区二区三区 | 久久久精品国产免大香伊| 亚洲精品国产一区二区精华液 | 精品黄色一级片| 亚洲色图88| 国产在线精品一区二区夜色| 中文字幕不卡的av| 欧美视频中文一区二区三区在线观看| 日韩欧美高清dvd碟片| 中文字幕日韩av综合精品| 国产精品成人一区二区| 欧美lavv| 成人一级片网站| 久久久久久久久亚洲精品| 天堂在线中文网官网| 精品淫伦v久久水蜜桃| 亚洲伦理一区| 99精品久久只有精品| 亚洲午夜精品网| 亚洲精品在线观看网站| 久久久久久中文字幕| 国产91精品一区二区绿帽| 国产日韩亚洲欧美在线| 2023欧美最顶级a∨艳星| 亚洲区欧洲区| 国产伦精品一区二区三区在线播放 | 妖精视频成人观看www| 国产精品18久久久| 一区二区在线观看免费视频播放| 91精品黄色片免费大全| 国产亚洲欧美日韩精品| 国产精品久久久久影院日本| 亚洲国内在线| av网站免费| 欧美人与禽猛交乱配| 日本欧美韩国国产| 日韩电影免费一区| 亚洲欧洲日本在线| 精品少妇一区二区三区视频免付费| 欧美成人午夜影院| 国产丝袜不卡| 国产精品免费看久久久香蕉| 久久资源av| 九七伦理97伦理手机| 成人免费观看在线观看| 欧美3p视频| 99久久国产免费看| 3d动漫精品啪啪1区2区免费 | 欧美岛国在线观看| 欧美女v视频| 亚洲高清视频中文字幕| 欧美色视频免费| 精品色蜜蜜精品视频在线观看| 一区二区在线免费观看| 亚洲国产中文字幕久久网| 国产成人亚洲综合91精品| 欧美大片免费观看| 好看的av在线不卡观看| 久久精品一二三区| 国产精品jizz在线观看美国| 品久久久久久久久久96高清| 校园春色综合网| 亚洲天堂第一页| 正在播放亚洲一区| 浅井舞香一区二区| 成人国产在线看| 国产精品实拍| 精品99在线| 26uuuu精品一区二区| 欧美精品一区二区久久婷婷| 91久久精品国产91久久性色| 日本精品免费在线观看| 视频在线观看入口黄最新永久免费国产| re久久精品视频| 久久精品人人做| 亚洲色图第一页| 免费试看一区| 美女毛片在线看| 国产成人三级| 国产亚洲视频系列| 亚洲欧美一区二区激情| 日产中文字幕在线精品一区 | 欧美性猛交久久久乱大交小说| 成人网址大全| 欧美性色黄大片手机版| 在线天堂中文资源最新版| 欧美精品videofree1080p| 六月婷婷一区| 国产原创精品在线| 91麻豆精品国产| 久久国产精品色av免费看| 久久久久久九九九九| 国产亚洲制服色| 欧美成年黄网站色视频| 久久久精品影院| 在线视频观看日韩| 青青青在线播放| 亚洲精品自产拍| 玖玖玖视频精品| 国产精品久久久久久久久久久久久 | 国产大片在线免费观看| av一级亚洲| 国产精品综合av一区二区国产馆| 精品成人国产在线观看男人呻吟| 国产精品一区二区99| 亚洲乱码中文字幕久久孕妇黑人| 欧美日韩综合视频网址| 一区二区成人av| 国产又大又长又粗又黄| 免费在线看电影| 午夜一级久久| 又黄又爽在线免费观看| 日韩av影片在线观看| 综合视频在线| 九色porny在线观看| 日韩中文在线中文网在线观看| 91久久综合| 国产精品第12页| 一区二区三区蜜桃| 黄网站在线免费| 97久久精品视频| aaa亚洲精品| 香蕉视频亚洲一级| 三区精品视频观看| 69堂国产成人免费视频| 国产精品久久占久久| 成人在色线视频在线观看免费大全| 亚洲天堂网在线观看|