支撐Java NIO與NodeJS的底層技術(shù)
支撐Java NIO 與 NodeJS的底層技術(shù)
眾所周知在近幾個(gè)版本的Java中增加了一些對(duì)Java NIO、NIO2的支持,與此同時(shí)NodeJS技術(shù)棧中最為人稱道的優(yōu)勢(shì)之一就是其高性能IO,那么我們今天要討論的話題就是支撐這些技術(shù)的底層技術(shù)。
開始之前先要提出的一個(gè)問題是:
為什么NodeJS和Java NIO2沒有在更早的時(shí)間出現(xiàn)?
答案:個(gè)人認(rèn)為是底層的支撐技術(shù)還不成熟。
那么,底層技術(shù)指的是什么呢?對(duì)的,我想很多人已經(jīng)猜到,是操作系統(tǒng)技術(shù)。本文提出的兩個(gè)概念Java NIO2和NodeJS無一例外都是用戶態(tài)技術(shù)或者說是應(yīng)用層技術(shù),而這些應(yīng)用層技術(shù)是運(yùn)行于OS之上的,與此同時(shí)隨著操作系統(tǒng)的進(jìn)步,可以支撐的編程模型也更加的豐富??梢赃@么說,這兩項(xiàng)技術(shù)完全是為了應(yīng)用操作系統(tǒng)進(jìn)步帶來的紅利而進(jìn)化出來的技術(shù)。一般來說最先享受這種紅利的技術(shù)一定是C\C++,因?yàn)镺S的進(jìn)步最新提供的大部分是系統(tǒng)調(diào)用,而C\C++是最方便應(yīng)用這些系統(tǒng)調(diào)用的,但是同時(shí)也是最復(fù)雜的。其他平臺(tái)為了也獲得同樣的性能,就必須不斷的進(jìn)化,封裝,使用戶可以用上這些紅利,一旦那個(gè)平臺(tái)停滯更新,也就是這個(gè)平臺(tái)沒落的時(shí)候了。對(duì)用戶來說封裝的越方便,對(duì)用戶來說就越是友好,可能使用的人就越多。雖然很多人可以很快的寫出基于這些平臺(tái)的代碼,但是往往不得其精髓,因?yàn)楸举|(zhì)上還是不理解這些技術(shù)的動(dòng)機(jī)和原理。下面我們討論的這些技就是這兩項(xiàng)技術(shù)相關(guān)的底層技術(shù)。
不管哪一種OS設(shè)計(jì)中,下面5種IO模型都是必不可少的。
1. blocking I/O
2. nonblocking I/O
3. I/O multiplexing (select, poll and epoll)
4. signal driven I/O (SIGIO)
5. asynchronous I/O (the POSIX aio_ functions)
1. blocking I/O
如圖所示,這種IO模型的優(yōu)點(diǎn)是編程簡(jiǎn)單,也是OS最早支持的IO模型之一,缺點(diǎn)是系統(tǒng)調(diào)用阻塞用戶動(dòng)態(tài)線程執(zhí)行,從而造成CPU時(shí)間浪費(fèi),IO效率低。
2. nonblocking I/O
如圖所示,這種IO模型的一個(gè)改進(jìn)是IO是非阻塞了,但是需要長(zhǎng)輪詢,同樣浪費(fèi)CPU時(shí)鐘周期。
3. I/O multiplexing (select, poll and epoll)
如圖所示,這種IO模型是當(dāng)今OS提供的最穩(wěn)定的IO模型,大部分主流的應(yīng)用都是基于此種IO模型構(gòu)建的,比如NodeJS,但是這些平臺(tái)往往在這種模型之上增加一層封裝來直接支持AIO。
4. signal driven I/O (SIGIO)
如圖所示,資料記載這種IO模型由于對(duì)比模型3沒有性能優(yōu)勢(shì),同時(shí)由于系統(tǒng)支持不穩(wěn)定,很少為設(shè)計(jì)者采用。
5. asynchronous I/O (the POSIX aio_ functions)
如圖所示,此種IO模型是最完美的AIO,編程模型也最簡(jiǎn)單,但是能夠完美支持者個(gè)模型的OS很少,網(wǎng)上資料顯示Linux正在做這方面的努力,一旦OS在這個(gè)方面上取得進(jìn)展,編程框架,平臺(tái),編程模型可能還是需要有很大程度的簡(jiǎn)化。
雖然這種模型很少有OS的支持,但是并不是說現(xiàn)在就沒有這種AIO模型,很多框架做了這方面的工作,在用戶態(tài)模擬了AIO,使用戶可以更多的關(guān)注業(yè)務(wù)邏輯代碼。
6. 同步異步,阻塞和非阻塞
同步和異步是針對(duì)應(yīng)用程序和內(nèi)核的交互而言的。一直等到數(shù)據(jù)讀完再返回的是同步,直接返回的是異步。阻塞和非阻塞是對(duì)進(jìn)程、線程而言的,阻塞方式下讀取或者寫入線程一直等待,而非阻塞方式下,讀取或者寫入線程立即返回一個(gè)狀態(tài)值。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringCloud基于RestTemplate微服務(wù)項(xiàng)目案例解析
這篇文章主要介紹了SpringCloud基于RestTemplate微服務(wù)項(xiàng)目案例,在寫SpringCloud搭建微服務(wù)之前,先搭建一個(gè)不通過springcloud只通過SpringBoot和Mybatis進(jìn)行模塊之間通訊,通過一個(gè)案例給大家詳細(xì)說明,需要的朋友可以參考下2022-05-05細(xì)數(shù)java中Long與Integer比較容易犯的錯(cuò)誤總結(jié)
下面小編就為大家?guī)硪黄?xì)數(shù)java中Long與Integer比較容易犯的錯(cuò)誤總結(jié)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01mybatis 實(shí)現(xiàn)多條update同時(shí)執(zhí)行
這篇文章主要介紹了mybatis 實(shí)現(xiàn)多條update同時(shí)執(zhí)行,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01java自定義注解驗(yàn)證手機(jī)格式的實(shí)現(xiàn)示例
這篇文章主要介紹了java自定義注解驗(yàn)證手機(jī)格式的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03springboot實(shí)現(xiàn)通過路徑從磁盤直接讀取圖片
這篇文章主要介紹了springboot實(shí)現(xiàn)通過路徑從磁盤直接讀取圖片,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03springboot集成kafka消費(fèi)手動(dòng)啟動(dòng)停止操作
這篇文章主要介紹了springboot集成kafka消費(fèi)手動(dòng)啟動(dòng)停止操作,本文給大家介紹項(xiàng)目場(chǎng)景及解決分析,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09Java整合mybatis實(shí)現(xiàn)過濾數(shù)據(jù)
這篇文章主要介紹了Java整合mybatis實(shí)現(xiàn)過濾數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01Arthas在線java進(jìn)程診斷工具在線調(diào)試神器詳解
Arthas是 Alibaba 開源的Java診斷工具,深受開發(fā)者喜愛。這篇文章主要介紹了Arthas在線java進(jìn)程診斷工具 在線調(diào)試神器,需要的朋友可以參考下2021-11-11如何構(gòu)建可重復(fù)讀取inputStream的request
這篇文章主要介紹了如何構(gòu)建可重復(fù)讀取inputStream的request,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03