青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

同步、異步、阻塞、非阻塞的區別

阻塞、非阻塞、同步、異步 這四個概念很多人不能完全區別開,尤其是他們相互組合時同步阻塞,異步阻塞……
轉自:http://blog.chinaunix.net/uid-26606708-id-3175228.html

前4種模型的主要區別在于第一階段,因為它們的第二階段都是一樣的:在數據從內核緩沖區拷貝到進程緩沖區期間,進程阻塞與recvfrom這個系統調用中。

參考 Richard Stevens的“UNIX® Network Programming Volume 1, Third Edition: The Sockets Networking”。

Stevens一共提出了五種 IO Model:

  • blocking IO
  • nonblocking IO
  • IO multiplexing (select and poll)
  • signal driven IO (SIGIO)
  • asynchronous IO (the POSIX aio_functions)

先說一下IO發生時所涉及的對象和步驟。

一個輸入操作通常包括下面兩個階段:

  1. 等待數據準備好 (Waiting for the data to be ready)。對于一個套接口上的輸入操作,通常涉及等待數據從網絡到達,到達后它被拷貝到內核的某個緩沖區。
  2. 將數據從內核緩存區拷貝到進程緩沖區中 (Copying the data from the kernel to the process)

記住這兩個階段很重要,因為以下要討論的五種IO Model的區別就是在兩個階段上各有不同的情況。

Blocking I/O Model(阻塞I/O)

默認情況下所有的套接口都是blocking。

進程調用recvfrom,其系統調用直到數據報到達(第一階段)且被拷貝到應用進程的緩沖區中(第二階段)或者發生錯誤(最常見的錯誤是系統調用被信號中斷)才返回。進程在從調用recvfrom開始到它返回的整個過程是被阻塞的。 recvfrom成功返回后,應用進程開始處理數據報。

Nonblocking I/O Model(非阻塞I/O)

前三次調用recvfrom時數據還沒準備好,這是內核立即返回一個EWOULDBLOCK錯誤。第四次調用recvfrom時數據已準備好,它被拷貝到應用進程緩沖區,recvfrom接著成功返回,然后應用進程開始處理數據報。

這里最關鍵的一個操作就是輪詢(polling)。應用進程持續輪詢內核,以查看數據是否就緒。這樣做往往會耗費大量的CPU時間,這種模型通常會在專門提供某種功能的系統才有。

I/O Multiplexing Model(I/O復用模型)

當用戶進程調用了select,那么整個進程會被block,而同時,kernel會“監視”所有select負責的socket,當任何一個 socket中的數據準備好了,select就會返回套接字可讀這個條件,我們調用recvfrom把所讀數據報拷貝到應用程序進程緩沖區。

和blocking IO的圖比較,I/O復用并沒有顯示出什么優勢。事實上,可能稍有劣勢。因為這里需要使用兩個system call (select 和 recvfrom),而blocking IO只調用了一個system call。但是,用select的優勢在于它可以同時處理多個connection。(peakflys注: 常用的服務器網絡模型即是 多路復用IO調度+非阻塞fd+線程池)

Signal-Driven I/O Model(信號驅動I/O模型)

我們首先開啟套接口的信號驅動I/O功能,并通過sigaction系統調用安裝一個信號處理函數。該系統調用將立即返回,我們的進程這是并沒有被阻塞,而是繼續執行。當數據報準備好讀取時,內核就為該進程產生一個SIGIO信號。我們隨后既可以在信號處理函數中調用recvfrom讀取數據報,并通知主循環數據已準備好待處理,也可以立即通知主循環,讓它來讀取數據報。無論如何處理SIGIO信號,這種模型的優勢在于等待數據報到達(第一階段)期間,進程可以繼續執行,不被阻塞。

Asynchronous I/O Model(異步I/O模型)

進程發起read操作之后,立刻就可以開始去做其它的事。而另一方面,從kernel的角度,當它受到一個asynchronous read之后,首先它會立刻返回,所以不會對用戶進程產生任何block。然后,kernel會等待數據準備完成,然后將數據拷貝到用戶內存,當這一切都完成之后,kernel會給用戶進程發送一個signal,告訴它read操作完成了。

這個模型工作機制是:告訴內核啟動某個操作,并讓內核在整個操作(包括第二階段,即將數據從內核拷貝到進程緩沖區中)完成后通知我們。

這種模型和前一種模型區別在于:信號驅動I/O是由內核通知我們何時可以啟動一個I/O操作,而異步I/O模型是由內核通知我們I/O操作何時完成。

五種I/O模型介紹完了,下面來說說blocking和non-blocking的區別在哪,synchronous IO和asynchronous IO的區別在哪。

blocking I/Ovs non-blocking I/O :調用blocking IO會一直block住對應的進程直到操作完成,而non-blocking IO在kernel還準備數據的情況下會立刻返回。

synchronous I/O vs asynchronous I/O:

先看看這兩個定義:

A synchronous I/O operation causes the requesting process to be blocked until that I/O operation completes;

An asynchronous I/O operation does not cause the requesting process to be blocked;

兩者的區別就在于synchronous IO做”IO operation”的時候會將process阻塞。按照這個定義,之前所述前四種模型blocking I/O,non-blocking I/O,IO multiplexing,signal driven IO都屬于synchronous IO。有人可能會說,non-blocking IO并沒有被block啊。這里有個非常“狡猾”的地方,定義中所指的”IO operation”是指真實的IO操作,就是例子中的recvfrom這個system call。non-blocking IO在執行recvfrom這個system call的時候,如果kernel的數據沒有準備好,這時候不會block進程。但是,當kernel中數據準備好的時候,recvfrom會將數據從 kernel拷貝到用戶內存中,這個時候(第二階段)進程是被block了,在這段時間內,進程是被block的。而asynchronous IO則不一樣,當進程發起IO 操作之后,就直接返回再也不理睬了,直到kernel發送一個信號,告訴進程說IO完成。在這整個過程中,進程完全沒有被block。

各個IO Model的比較如圖所示:

前4種模型的主要區別在于第一階段,因為它們的第二階段都是一樣的:在數據從內核緩沖區拷貝到進程緩沖區期間,進程阻塞與recvfrom這個系統調用中。
(peakflys注:異步調用需要指定回調函數或者信號處理函數,所以和其他幾個模型的函數調用有明顯不同,linux下的異步調用庫有兩套,一套是linux內核提供的,一套是glibc提供的,前者執行異步調用時是進入系統內核,統一有IO調度器調度,后者是在調用進程里生成一個新的線程執行異步操作,同fd的異步操作在同一個線程執行)

posted on 2013-03-06 11:08 peakflys 閱讀(446) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導航

統計

公告

人不淡定的時候,就愛表現出來,敲代碼如此,偶爾的靈感亦如此……

常用鏈接

留言簿(4)

隨筆分類

隨筆檔案

文章檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧洲精品一区二区三区不卡 | 国产精品麻豆成人av电影艾秋| 久久免费精品日本久久中文字幕| 久久久噜噜噜久噜久久| 久久日韩粉嫩一区二区三区| 久热精品视频在线观看| 欧美大片一区二区三区| 欧美久久久久免费| 国产精品视频一区二区高潮| 国产亚洲永久域名| 亚洲人成网站999久久久综合 | 久久免费少妇高潮久久精品99| 蜜臀久久久99精品久久久久久| 亚洲国产经典视频| 99精品视频免费全部在线| 亚洲一区3d动漫同人无遮挡| 久久久久久久999精品视频| 欧美顶级大胆免费视频| 国产伦精品一区二区三区视频黑人 | 国产午夜精品一区理论片飘花| 国产日韩一区二区三区| 亚洲高清自拍| 亚洲一区三区电影在线观看| 久久午夜羞羞影院免费观看| 亚洲每日在线| 久久国产黑丝| 欧美日韩一区在线| 在线播放日韩欧美| 亚洲欧美另类在线| 欧美激情精品久久久久久蜜臀| 亚洲一区二区在线免费观看| 欧美成人国产| 国产一区二区三区久久| 亚洲午夜精品福利| 亚洲国产精品va在线观看黑人| 午夜精品一区二区三区在线| 欧美激情一区二区三区| 在线观看视频一区二区| 午夜精品视频网站| 亚洲美女黄网| 欧美激情va永久在线播放| 韩国成人理伦片免费播放| 欧美一区二区三区男人的天堂| 亚洲精品在线视频| 老鸭窝毛片一区二区三区| 国产视频欧美视频| 欧美一区二区三区另类| 亚洲天堂av在线免费| 欧美日本在线视频| 亚洲另类在线一区| 欧美国产乱视频| 久久精品视频免费观看| 国产一区二区三区的电影| 欧美主播一区二区三区美女 久久精品人| 亚洲三级影片| 欧美日韩情趣电影| 一区二区高清| 一本色道久久综合亚洲精品不| 欧美日韩高清免费| 亚洲深夜福利网站| 亚洲视频免费在线| 国产精品尤物| 久久视频免费观看| 久久人人爽人人爽爽久久| 136国产福利精品导航| 免费视频亚洲| 欧美激情第五页| 正在播放亚洲| 亚洲综合色自拍一区| 国产日本欧美一区二区三区| 久久久久久亚洲精品杨幂换脸 | 老司机午夜精品| 玖玖在线精品| 99精品黄色片免费大全| 一区二区欧美激情| 国产精品看片资源| 亚洲经典三级| 麻豆亚洲精品| 久久中文精品| 日韩一级精品视频在线观看| 亚洲精品视频一区| 国产精品美女午夜av| 久久精品国产第一区二区三区| 久久久www成人免费毛片麻豆| 亚洲国产精品电影| 99re8这里有精品热视频免费| 国产精品区一区二区三区| 久久久免费精品视频| 欧美成人精品在线观看| 亚洲尤物在线| 久久亚洲私人国产精品va媚药| 99国产精品视频免费观看| 亚洲综合精品四区| 91久久精品一区二区别| 亚洲影院色无极综合| 亚洲国产精品va在看黑人| 在线视频你懂得一区| 在线观看91精品国产入口| 一区二区高清在线观看| 在线看国产日韩| 亚洲制服av| 亚洲精品一区二区三区不| 午夜精品在线| 亚洲一区二区三区四区五区黄| 久久婷婷一区| 久久av资源网站| 欧美视频免费在线| 亚洲成人在线网| 美女视频黄a大片欧美| 欧美精品一区二区三区高清aⅴ| 欧美一区二区三区免费视| 欧美激情视频在线播放 | 性18欧美另类| 一区二区欧美在线| 久久精品国产2020观看福利| 亚洲特黄一级片| 免费不卡欧美自拍视频| 久久久久欧美精品| 国产精品午夜在线| 一本久久精品一区二区| 日韩亚洲视频在线| 欧美成熟视频| 亚洲国产精品毛片| 亚洲国产精品一区在线观看不卡| 午夜精彩视频在线观看不卡| 亚洲视频欧美在线| 欧美大尺度在线| 亚洲电影免费观看高清完整版在线 | 国产精品成人一区二区网站软件 | 午夜精品福利一区二区三区av| 亚洲免费av网站| 久久久噜噜噜久久久| 久久久久久午夜| 国语自产精品视频在线看8查询8 | 日韩一级精品| 亚洲一区二区成人| 欧美视频一二三区| 亚洲一区二区免费看| 亚洲欧美在线aaa| 国产酒店精品激情| 欧美一区二区精品| 久久久精品午夜少妇| 激情欧美日韩一区| 免费亚洲电影| 亚洲精品社区| 午夜精品国产更新| 国产午夜精品一区二区三区视频| 欧美尤物巨大精品爽| 欧美.www| 9色porny自拍视频一区二区| 欧美日韩专区在线| 亚洲欧美日韩国产| 欧美成人免费在线观看| 日韩天堂av| 国产精品一区二区欧美| 久久av在线看| 91久久一区二区| 羞羞色国产精品| 尹人成人综合网| 欧美日韩喷水| 久久精品国产69国产精品亚洲| 亚洲高清免费| 性欧美8khd高清极品| 精品成人在线观看| 欧美日韩日韩| 久久综合久久综合久久综合| 亚洲精品视频免费在线观看| 久久成人羞羞网站| 亚洲美女毛片| 国产综合久久久久影院| 在线一区二区视频| 欧美四级在线观看| 久久久久免费| 一区二区高清视频| 欧美风情在线| 久久精品成人一区二区三区| 亚洲精品视频在线播放| 国产欧美婷婷中文| 欧美成人午夜| 久久国产加勒比精品无码| 99视频在线精品国自产拍免费观看| 久久精品观看| 亚洲在线观看视频| 亚洲精品一区二区三区福利| 国产亚洲精品aa| 欧美午夜不卡影院在线观看完整版免费| 久久国产精品久久w女人spa| 亚洲国产精品电影在线观看| 久久久久久久久久久久久女国产乱 | 一本一本久久a久久精品牛牛影视| 久久久久久久综合狠狠综合| 亚洲精品美女在线观看播放| 99v久久综合狠狠综合久久| 一区二区三区免费在线观看| 噜噜噜噜噜久久久久久91| 亚洲影院免费观看| 日韩视频国产视频| 亚洲欧洲中文日韩久久av乱码| 国产在线视频欧美| 国产午夜久久久久|