詳解node單線程實(shí)現(xiàn)高并發(fā)原理與node異步I/O
一、node單線程實(shí)現(xiàn)高并發(fā)原理
眾所周知nodejs是單線程且支持高并發(fā)的腳本語(yǔ)言??蔀槭裁磫尉€程的nodejs可以支持高并發(fā)呢?很多人都不明白其原理,下面我來(lái)談?wù)勎业睦斫猓?/p>
1. node的優(yōu)點(diǎn):I/O密集型處理是node的強(qiáng)項(xiàng),因?yàn)閚ode的I/O請(qǐng)求都是異步的(如:sql查詢請(qǐng)求、文件流操作操作請(qǐng)求、http請(qǐng)求...)
a. 什么是異步?
異步:發(fā)出操作指令,然后就可以去做別的事情了,所有操作完成后再執(zhí)行回調(diào)
異步的實(shí)現(xiàn)原理:
// 第一步:定義變量
let a = 1;
// 第二步:發(fā)出指令,然后把回調(diào)函數(shù)加入異步隊(duì)列(回調(diào)函數(shù)并沒(méi)有執(zhí)行)
setTimeout(() => {
console.log(a);
}, 0)
// 第三步:賦值,回調(diào)函數(shù)沒(méi)有執(zhí)行
a = 2;
// 第四步:發(fā)出指令,然后把回調(diào)函數(shù)加入異步隊(duì)列(回調(diào)函數(shù)并沒(méi)有執(zhí)行)
setTimeout(() => {
console.log(a);
}, 0)
// 第五步:賦值,回調(diào)函數(shù)沒(méi)有執(zhí)行
a = 3;
// 當(dāng)所有代碼執(zhí)行完畢,cpu空閑下來(lái)了,就會(huì)開(kāi)始執(zhí)行異步隊(duì)列里面的回調(diào)函數(shù)
// 所以最后控制臺(tái)輸出:3 3
b. 什么是異步I/O?
異步I/O顧名思義就是異步的發(fā)出I/O請(qǐng)求
c. 雖然nodejs可以異步的發(fā)出I/O請(qǐng)求,但nodejs不支持多線程,為啥就可以支持高并發(fā)呢?
因?yàn)閚odejs的I/O操作,底層是開(kāi)啟了多線程的
當(dāng)同時(shí)有多個(gè)IO請(qǐng)求時(shí),主線程會(huì)創(chuàng)建多個(gè)eio線程,以提高IO請(qǐng)求的處理速度
額外知識(shí)點(diǎn):
d. 雖然nodejs的I/O操作開(kāi)啟了多線程,但是所有線程都是基于主線程開(kāi)啟的只能跑在一個(gè)進(jìn)程當(dāng)中還是不能充分利用cpu資源
pm2進(jìn)程管理器可以解決這個(gè)問(wèn)題
pm2 是一個(gè)帶有負(fù)載均衡功能的Node應(yīng)用的進(jìn)程管理器.
e. cpu核數(shù)與線程之間的關(guān)系
在過(guò)去單CPU時(shí)代,單任務(wù)在一個(gè)時(shí)間點(diǎn)只能執(zhí)行單一程序。之后發(fā)展到多任務(wù)階段,計(jì)算機(jī)能在同一時(shí)間點(diǎn)并行執(zhí)行多任務(wù)或多進(jìn)程。雖然并不是真正意義上的“同一時(shí)間點(diǎn)”,而是多個(gè)任務(wù)或進(jìn)程共享一個(gè)CPU,并交由操作系統(tǒng)來(lái)完成多任務(wù)間對(duì)CPU的運(yùn)行切換,以使得每個(gè)任務(wù)都有機(jī)會(huì)獲得一定的時(shí)間片運(yùn)行。而現(xiàn)在多核CPU的情況下,同一時(shí)間點(diǎn)可以執(zhí)行多個(gè)任務(wù),具體到這個(gè)任務(wù)在CPU哪個(gè)核上運(yùn)行,這個(gè)就跟操作系統(tǒng)和CPU本身的設(shè)計(jì)相關(guān)了
2. node的缺點(diǎn):不擅長(zhǎng)cpu密集型的操作
a. 什么是cpu密集型操作(復(fù)雜的運(yùn)算、圖片的操作)
// 這就是一個(gè)cpu密集型的操作
for (let i = 0; i < 1000000; i++) {
console.log(i);
}
b. nodejs為什么不擅長(zhǎng)cpu密集型操作
因?yàn)閚odejs是單線程的
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
node.js中的querystring.unescape方法使用說(shuō)明
這篇文章主要介紹了node.js中的querystring.unescape方法使用說(shuō)明,本文介紹了querystring.unescape的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12
使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解
這篇文章主要為大家介紹了使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
nodejs連接mysql數(shù)據(jù)庫(kù)簡(jiǎn)單封裝示例-mysql模塊
本篇文章主要介紹了nodejs連接mysql數(shù)據(jù)庫(kù)簡(jiǎn)單封裝(mysql模塊),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-04-04
Node.js API詳解之 dgram模塊用法實(shí)例分析
這篇文章主要介紹了Node.js API詳解之 dgram模塊用法,結(jié)合實(shí)例形式分析了Node.js API中dgram模塊基本功能、函數(shù)、使用方法及操作注意事項(xiàng),需要的朋友可以參考下2020-06-06
jQuery+koa2實(shí)現(xiàn)簡(jiǎn)單的Ajax請(qǐng)求的示例
這篇文章主要介紹了jQuery+koa2實(shí)現(xiàn)簡(jiǎn)單的Ajax請(qǐng)求的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
NodeJS實(shí)現(xiàn)視頻轉(zhuǎn)碼的示例代碼
本篇文章主要介紹了NodeJS實(shí)現(xiàn)視頻轉(zhuǎn)碼的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
用npm install時(shí)報(bào)錯(cuò)node-sass npm ERR command
在用npm install時(shí)報(bào)錯(cuò)npm ERR! path D:…\node-sass和npm ERR! command failed 問(wèn)題,本文給大家介紹了如何解決這個(gè)問(wèn)題,文中通過(guò)圖文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03
node.js解決客戶端請(qǐng)求數(shù)據(jù)里面中文亂碼的事件方法
本文主要介紹了node.js解決客戶端請(qǐng)求數(shù)據(jù)里面中文亂碼的事件方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12

