欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Linux 網(wǎng)絡(luò) I/O 模型簡介(圖文)

 更新時(shí)間:2017年12月29日 11:41:05   作者:anxpp  
這篇文章主要介紹了淺談Linux 網(wǎng)絡(luò) I/O 模型簡介(圖文),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

1、介紹

Linux 的內(nèi)核將所有外部設(shè)備都看做一個(gè)文件來操作(一切皆文件),對一個(gè)文件的讀寫操作會調(diào)用內(nèi)核提供的系統(tǒng)命令,返回一個(gè)file descriptor(fd,文件描述符)。而對一個(gè)socket的讀寫也會有響應(yīng)的描述符,稱為socket fd(socket文件描述符),描述符就是一個(gè)數(shù)字,指向內(nèi)核中的一個(gè)結(jié)構(gòu)體(文件路徑,數(shù)據(jù)區(qū)等一些屬性)。

根據(jù)UNIX網(wǎng)絡(luò)編程對I/O模型的分類,UNIX提供了5種I/O模型。

1.1、阻塞I/O模型

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

比如I/O模型下的套接字接口:在進(jìn)程空間中調(diào)用recvfrom,其系統(tǒng)調(diào)用直到數(shù)據(jù)包到達(dá)且被復(fù)制到應(yīng)用進(jìn)程的緩沖區(qū)中或者發(fā)生錯(cuò)誤時(shí)才返回,在此期間一直等待。

進(jìn)程在調(diào)用recvfrom開始到它返回的整段時(shí)間內(nèi)都是被阻塞的,所以叫阻塞I/O模型。

圖示:

    01

1.2、非阻塞I/O模型

recvfrom從應(yīng)用層到內(nèi)核的時(shí)候,就直接返回一個(gè)EWOULDBLOCK錯(cuò)誤,一般都對非阻塞I/O模型進(jìn)行輪詢檢查這個(gè)狀態(tài),看內(nèi)核是不是有數(shù)據(jù)到來。

圖示:

    02

1.3、I/O復(fù)用模型

Linux提供select/poll,進(jìn)程通過將一個(gè)或多個(gè)fd傳遞給select或poll系統(tǒng)調(diào)用,阻塞在select操作上,這樣,select/poll可以幫我們偵測多個(gè)fd是否處于就緒狀態(tài)。

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

Linux還提供一個(gè)epoll系統(tǒng)調(diào)用,epoll使用基于事件驅(qū)動方式代替順序掃描,因此性能更高。當(dāng)有fd就緒時(shí),立即回調(diào)函數(shù)rollback。

圖示:

    03

1.4、信號驅(qū)動I/O模型

首先開啟套接口信號驅(qū)動I/O功能,并通過系統(tǒng)調(diào)用sigaction執(zhí)行一個(gè)信號處理函數(shù)(此系統(tǒng)調(diào)用立即返回,進(jìn)程繼續(xù)工作,非阻塞)。當(dāng)數(shù)據(jù)準(zhǔn)備就緒時(shí),就為改進(jìn)程生成一個(gè)SIGIO信號,通過信號回調(diào)通知應(yīng)用程序調(diào)用recvfrom來讀取數(shù)據(jù),并通知主循環(huán)函數(shù)處理樹立。

圖示:

04

1.5、異步I/O

告知內(nèi)核啟動某個(gè)操作,并讓內(nèi)核在整個(gè)操作完成后(包括數(shù)據(jù)的復(fù)制)通知進(jìn)程。

信號驅(qū)動I/O模型通知的是何時(shí)可以開始一個(gè)I/O操作,異步I/O模型有內(nèi)核通知I/O操作何時(shí)已經(jīng)完成。

圖示:

05

2、I/O多路復(fù)用技術(shù)

I/O編程中,需要處理多個(gè)客戶端接入請求時(shí),可以利用多線程或者I/O多路復(fù)用技術(shù)進(jìn)行處理。

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

與傳統(tǒng)的多線程模型相比,I/O多路復(fù)用的最大優(yōu)勢就是系統(tǒng)開銷小,系統(tǒng)不需要?jiǎng)?chuàng)建新的額外線程,也不需要維護(hù)這些線程的運(yùn)行,降低了系統(tǒng)的維護(hù)工作量,節(jié)省了系統(tǒng)資源。

主要的應(yīng)用場景:

  1. 服務(wù)器需要同時(shí)處理多個(gè)處于監(jiān)聽狀態(tài)或多個(gè)連接狀態(tài)的套接字。
  2. 服務(wù)器需要同時(shí)處理多種網(wǎng)絡(luò)協(xié)議的套接字。

支持I/O多路復(fù)用的系統(tǒng)調(diào)用主要有select、pselect、poll、epoll。

而當(dāng)前推薦使用的是epoll,優(yōu)勢如下:

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

3、Java中的網(wǎng)絡(luò)IO編程

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

已專門出了文章介紹:Java 網(wǎng)絡(luò)IO編程總結(jié)(BIO、NIO、AIO均含完整實(shí)例代碼)

相關(guān)文章

  • 服務(wù)器安裝寶塔面板無法遠(yuǎn)程連接數(shù)據(jù)庫的解決方法

    服務(wù)器安裝寶塔面板無法遠(yuǎn)程連接數(shù)據(jù)庫的解決方法

    這篇文章主要介紹了服務(wù)器安裝寶塔面板無法遠(yuǎn)程連接數(shù)據(jù)庫的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Linux下Nodejs安裝步驟(完整詳細(xì))

    Linux下Nodejs安裝步驟(完整詳細(xì))

    這篇文章主要介紹了Linux下Nodejs安裝步驟(完整詳細(xì)),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-01-01
  • 在Linux服務(wù)器上安裝 memcached的基本操作

    在Linux服務(wù)器上安裝 memcached的基本操作

    本文分步驟給大家詳細(xì)介紹了linux服務(wù)器上安裝memcached的操作方法,非常不錯(cuò),需要的朋友參考下吧
    2016-12-12
  • CentOS7安裝mysql5.7解壓縮版簡明教程

    CentOS7安裝mysql5.7解壓縮版簡明教程

    這篇文章主要介紹了CentOS7安裝mysql5.7解壓縮版,簡單介紹了CentOS7環(huán)境下的mysql5.7壓縮版下載、解壓、安裝、配置、密碼設(shè)置等相關(guān)命令及操作技巧,需要的朋友可以參考下
    2018-03-03
  • Linux之進(jìn)程間通信(共享內(nèi)存【mmap實(shí)現(xiàn)+系統(tǒng)V】)

    Linux之進(jìn)程間通信(共享內(nèi)存【mmap實(shí)現(xiàn)+系統(tǒng)V】)

    這篇文章主要介紹了Linux之進(jìn)程間通信(共享內(nèi)存【mmap實(shí)現(xiàn)+系統(tǒng)V】),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 詳解linux電源管理驅(qū)動編寫

    詳解linux電源管理驅(qū)動編寫

    這篇文章主要介紹了詳解linux電源管理驅(qū)動編寫,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • linux系統(tǒng)安裝msf的過程詳解

    linux系統(tǒng)安裝msf的過程詳解

    這篇文章主要介紹了linux系統(tǒng)安裝msf的過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • linux系統(tǒng) java環(huán)境變量的配置方法

    linux系統(tǒng) java環(huán)境變量的配置方法

    這篇文章主要介紹了配置linux系統(tǒng) java環(huán)境變量的相關(guān)知識,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11
  • Linux中查看指定文件夾內(nèi)各個(gè)子文件夾內(nèi)的文件數(shù)量

    Linux中查看指定文件夾內(nèi)各個(gè)子文件夾內(nèi)的文件數(shù)量

    今天小編就為大家分享一篇關(guān)于Linux中查看指定文件夾內(nèi)各個(gè)子文件夾內(nèi)的文件數(shù)量,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • Linux中環(huán)境變量配置的步驟詳解

    Linux中環(huán)境變量配置的步驟詳解

    Linux中環(huán)境變量包括系統(tǒng)級和用戶級,系統(tǒng)級的環(huán)境變量是每個(gè)登錄到系統(tǒng)的用戶都要讀取的系統(tǒng)變量,而用戶級的環(huán)境變量則是該用戶使用系統(tǒng)時(shí)加載的環(huán)境變量。所以下面這篇文章主要給大家介紹了關(guān)于Linux中環(huán)境變量配置的相關(guān)資料,需要的朋友可以參考下。
    2017-07-07

最新評論