91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

淺談Linux 網絡 I/O 模型簡介(圖文)

發布時間:2020-09-21 16:35:32 來源:腳本之家 閱讀:118 作者:anxpp 欄目:服務器

1、介紹

Linux 的內核將所有外部設備都看做一個文件來操作(一切皆文件),對一個文件的讀寫操作會調用內核提供的系統命令,返回一個file descriptor(fd,文件描述符)。而對一個socket的讀寫也會有響應的描述符,稱為socket fd(socket文件描述符),描述符就是一個數字,指向內核中的一個結構體(文件路徑,數據區等一些屬性)。

根據UNIX網絡編程對I/O模型的分類,UNIX提供了5種I/O模型。

1.1、阻塞I/O模型

最常用的I/O模型,默認情況下,所有文件操作都是阻塞的。

比如I/O模型下的套接字接口:在進程空間中調用recvfrom,其系統調用直到數據包到達且被復制到應用進程的緩沖區中或者發生錯誤時才返回,在此期間一直等待。

進程在調用recvfrom開始到它返回的整段時間內都是被阻塞的,所以叫阻塞I/O模型。

圖示:

    淺談Linux 網絡 I/O 模型簡介(圖文)

1.2、非阻塞I/O模型

recvfrom從應用層到內核的時候,就直接返回一個EWOULDBLOCK錯誤,一般都對非阻塞I/O模型進行輪詢檢查這個狀態,看內核是不是有數據到來。

圖示:

    淺談Linux 網絡 I/O 模型簡介(圖文)

1.3、I/O復用模型

Linux提供select/poll,進程通過將一個或多個fd傳遞給select或poll系統調用,阻塞在select操作上,這樣,select/poll可以幫我們偵測多個fd是否處于就緒狀態。

select/poll是順序掃描fd是否就緒,而且支持的fd數量有限,因此它的使用受到了一些制約。

Linux還提供一個epoll系統調用,epoll使用基于事件驅動方式代替順序掃描,因此性能更高。當有fd就緒時,立即回調函數rollback。

圖示:

    淺談Linux 網絡 I/O 模型簡介(圖文)

1.4、信號驅動I/O模型

首先開啟套接口信號驅動I/O功能,并通過系統調用sigaction執行一個信號處理函數(此系統調用立即返回,進程繼續工作,非阻塞)。當數據準備就緒時,就為改進程生成一個SIGIO信號,通過信號回調通知應用程序調用recvfrom來讀取數據,并通知主循環函數處理樹立。

圖示:

淺談Linux 網絡 I/O 模型簡介(圖文)

1.5、異步I/O

告知內核啟動某個操作,并讓內核在整個操作完成后(包括數據的復制)通知進程。

信號驅動I/O模型通知的是何時可以開始一個I/O操作,異步I/O模型有內核通知I/O操作何時已經完成。

圖示:

淺談Linux 網絡 I/O 模型簡介(圖文)

2、I/O多路復用技術

I/O編程中,需要處理多個客戶端接入請求時,可以利用多線程或者I/O多路復用技術進行處理。

正如前面的簡介,I/O多路復用技術通過把多個I/O的阻塞復用到同一個select的阻塞上,從而使得系統在單線程的情況下可以同時處理多個客戶端請求。

與傳統的多線程模型相比,I/O多路復用的最大優勢就是系統開銷小,系統不需要創建新的額外線程,也不需要維護這些線程的運行,降低了系統的維護工作量,節省了系統資源。

主要的應用場景:

  1. 服務器需要同時處理多個處于監聽狀態或多個連接狀態的套接字。
  2. 服務器需要同時處理多種網絡協議的套接字。

支持I/O多路復用的系統調用主要有select、pselect、poll、epoll。

而當前推薦使用的是epoll,優勢如下:

  1. 支持一個進程打開的socket fd不受限制。
  2. I/O效率不會隨著fd數目的增加而線性下將。
  3. 使用mmap加速內核與用戶空間的消息傳遞。
  4. epoll擁有更加簡單的API。

3、Java中的網絡IO編程

如果只是做Java開發,以上內容只需了解即可,不必深究(隨便說說而已)。

已專門出了文章介紹:Java 網絡IO編程總結(BIO、NIO、AIO均含完整實例代碼)

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海宁市| 马关县| 盐源县| 雷州市| 甘孜县| 隆昌县| 夏津县| 衡阳县| 阜新市| 文山县| 诏安县| 灵武市| 石门县| 五家渠市| 桂东县| 库尔勒市| 泰兴市| 罗江县| 墨江| 阜阳市| 垫江县| 南郑县| 凌海市| 隆尧县| 萝北县| 长子县| 游戏| 永靖县| 福泉市| 五常市| 军事| 丹巴县| 建德市| 万荣县| 海口市| 黄山市| 望都县| 麻阳| 红河县| 阿鲁科尔沁旗| 来安县|