Linux里有五種IO模型:阻塞IO、非阻塞IO、多路復(fù)用IO、信號驅(qū)動式IO和異步IO,我發(fā)現(xiàn)這五種IO模型,其實能和吃飯這件事關(guān)聯(lián)起來。
阻塞IO(Blocking I/O)
阻塞IO是最常見的IO模型。
當(dāng)發(fā)起一個IO操作時,比如讀取數(shù)據(jù),系統(tǒng)會調(diào)用read()函數(shù)。如果請求的數(shù)據(jù)沒有準備好,此時進程會被掛起(blocked),進入等待狀態(tài)。直到數(shù)據(jù)準備好,而且復(fù)制到應(yīng)用進程的緩沖區(qū),這時候才會返回。
從調(diào)用到返回,整個時間段都是阻塞的,所以被稱為阻塞IO。
阻塞IO
就像是手機沒電的時候,去飯館吃飯,我點完菜,只能等著廚師做好,服務(wù)員端上來,我才能愉快干飯。這段時間,我就只能坐在座位上干等。
非阻塞IO(Non-Blocking I/O)
阻塞IO,還是比較浪費資源的,那么非阻塞IO就來了。
所謂非阻塞IO,是在調(diào)用IO操作時,如果緩沖區(qū)沒有數(shù)據(jù)的話,直接返回一個錯誤碼。應(yīng)用進程需要不斷輪詢,來檢查數(shù)據(jù)是否準備好。數(shù)據(jù)準備好了,就返回數(shù)據(jù)。
非阻塞IO
就像是我奢侈一把,想吃個西餐,于是就去了肯德基,點完餐,我就可以坐著刷刷手機。當(dāng)然,我還需要時不時地看看我的餐是不是已經(jīng)備好,餐備好了,就去取一下。
多路復(fù)用IO(I/O Multiplexing)
雖然非阻塞IO相比阻塞IO,性能提升了很多,但是輪詢過程中,還是有大量的系統(tǒng)調(diào)用,上下文切換的開銷比較大。
那么,多路復(fù)用IO就來了。
多路指的是多個數(shù)據(jù)通道,復(fù)用指的是一個進程可以同時監(jiān)控多個文件描述符(比如socket),當(dāng)某個文件描述符狀態(tài)發(fā)生變化(比如變得可讀或可寫),多路復(fù)用的函數(shù)將返回變化的文件描述符。
這樣,在數(shù)據(jù)傳輸過程中,同一個進程中不同的任務(wù)都能被處理。特點是在數(shù)據(jù)傳輸過程中,進程能夠同時處理多個任務(wù),提高了程序的效率。
select、poll、epoll 等都是 I/O 多路復(fù)用的具體實現(xiàn)。
以select/poll為例,進程通過將一個或多個fd傳遞給select或poll系統(tǒng)調(diào)用,阻塞在select操作上,這樣select/poll可以偵測多個fd是否處于就緒狀態(tài)。當(dāng)有fd就緒時,立即回調(diào)函數(shù)rollback,接下來就可以進行讀取。
多路復(fù)用IO
就像是我想吃頓好的,于是選擇去吃自助餐,自助餐有很多餐區(qū),我先看看哪個餐區(qū)有我想吃的菜,然后端著盤子去取就行了,一個人就可以取多個菜,肉、蔬菜、水果,什么都能吃一點,而且不用怎么等。
信號驅(qū)動式IO(Signal-Driven I/O)
信號驅(qū)動式IO利用信號機制來進行數(shù)據(jù)傳輸。
進程首先告訴內(nèi)核,當(dāng)數(shù)據(jù)準備好時,請發(fā)送一個SIGIO信號。進程繼續(xù)執(zhí)行其他任務(wù),等到收到信號后,再開始進行數(shù)據(jù)傳輸。
信號驅(qū)動IO
就像是我去吃飯,外帶,跟服務(wù)員打聲招呼,餐好了通知我,這時候我就可以去干其它事情,餐備好之后,服務(wù)員通知我,我取餐就行了。
異步IO(Asynchronous I/O)
異步IO是指當(dāng)發(fā)起一個IO操作后,系統(tǒng)會立即返回。異步IO操作在后臺進行數(shù)據(jù)傳輸,數(shù)據(jù)傳輸完成后,系統(tǒng)將通知進程。這樣,在整個數(shù)據(jù)傳輸?shù)倪^程中,進程都可以執(zhí)行其他任務(wù),不需要等待。
異步IO
就像是準備吃飯了,我自己懶得動,直接在某團上點個餐,點完之后愛干啥干啥,等著快遞小哥給我送到就行了。
可以看到,阻塞和非阻塞主要指的是等待數(shù)據(jù)這個過程應(yīng)用進程需不需要掛起,同步和異步指的是等待數(shù)據(jù)和數(shù)據(jù)拷貝這兩個過程應(yīng)用進程需不需要掛起,只有異步IO做到了完全異步。
-
IO
+關(guān)注
關(guān)注
0文章
483瀏覽量
40033 -
Linux
+關(guān)注
關(guān)注
87文章
11420瀏覽量
212361
原文標題:一頓飯的事兒,搞懂 Linux 5 種 IO 模型
文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
Linux驅(qū)動開發(fā)之IO模型介紹
Java NIO編程理論基礎(chǔ)之Java IO及linux網(wǎng)絡(luò)IO模型發(fā)展
一文詳解linux的分頁模型

Linux的5種IO模型
網(wǎng)絡(luò)IO模型:阻塞與非阻塞

多路IO復(fù)用模型和異步IO模型介紹

linux異步io框架iouring應(yīng)用

評論