nodejs如何解決高并發(fā)問題
Node可以在不新增額外線程的情況下,依然可以對任務(wù)進行并發(fā)處理 —— Node.js是單線程的。
它通過事件循環(huán)(event loop)來實現(xiàn)并發(fā)操作,對此,我們應(yīng)該要充分利用這一點 —— 盡可能的避免阻塞操作,取而代之,多使用非阻塞操作。
node單線程實現(xiàn)高并發(fā)原理
眾所周知nodejs是單線程且支持高并發(fā)的腳本語言。
可為什么單線程的nodejs可以支持高并發(fā)呢?
很多人都不明白其原理,下面我來談?wù)勎业睦斫猓?/p>
node的優(yōu)點
I/O密集型處理是node的強項,因為node的I/O請求都是異步的(如:sql查詢請求、文件流操作操作請求、http請求...)
- a. 什么是異步?
異步:發(fā)出操作指令,然后就可以去做別的事情了(主線程不需要等待),所有操作完成后再執(zhí)行回調(diào)
異步的示例:
// 第一步:定義變量 let a = 1; // 第二步:發(fā)出指令,然后把回調(diào)函數(shù)加入事件隊列(回調(diào)函數(shù)并沒有執(zhí)行) setTimeout(() => { console.log(a); }, 0) // 第三步:賦值,回調(diào)函數(shù)沒有執(zhí)行 a = 2; // 第四步:發(fā)出指令,然后把回調(diào)函數(shù)加入異步隊列(回調(diào)函數(shù)并沒有執(zhí)行) setTimeout(() => { console.log(a); }, 0) // 第五步:賦值,回調(diào)函數(shù)沒有執(zhí)行 a = 3; // 當(dāng)所有代碼執(zhí)行完畢,cpu空閑下來了,就會開始遍歷執(zhí)行事件隊列里面的回調(diào)函數(shù) // 所以最后控制臺輸出:3 3
- b. 擁有異步I/O的node為什么可以支持高并發(fā)呢?
因為I/O操作是由node的工作線程去執(zhí)行的(nodejs底層的libuv是多線程的線程池用來并行io操作),且主線程是不需要等待結(jié)果返回的,只要發(fā)出指令馬上就可以去忙其他事情了。
額外知識點
- c. 雖然nodejs的I/O操作開啟了多線程,但是所有線程都是基于node服務(wù)進程開啟的,并不能充分利用cpu資源
pm2進程管理器可以解決這個問題
pm2 是一個帶有負載均衡功能的Node應(yīng)用的進程管理器.
- d. cpu核數(shù)與線程之間的關(guān)系
在過去單CPU時代,單任務(wù)在一個時間點只能執(zhí)行單一程序。之后發(fā)展到多任務(wù)階段,計算機能在同一時間點并行執(zhí)行多任務(wù)或多進程。
雖然并不是真正意義上的“同一時間點”,而是多個任務(wù)或進程共享一個CPU,并交由操作系統(tǒng)來完成多任務(wù)間對CPU的運行切換,以使得每個任務(wù)都有機會獲得一定的時間片運行。
而現(xiàn)在多核CPU的情況下,同一時間點可以執(zhí)行多個任務(wù),具體到這個任務(wù)在CPU哪個核上運行,這個就跟操作系統(tǒng)和CPU本身的設(shè)計相關(guān)了
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
NodeJS http模塊用法示例【創(chuàng)建web服務(wù)器/客戶端】
這篇文章主要介紹了NodeJS http模塊用法,結(jié)合實例形式分析了node.js創(chuàng)建web服務(wù)器與客戶端,進行HTTP通信的相關(guān)操作技巧,需要的朋友可以參考下2019-11-11nodejs同步調(diào)用獲取mysql數(shù)據(jù)時遇到的大坑
今天小編就為大家分享一篇關(guān)于nodejs同步調(diào)用獲取mysql數(shù)據(jù)時遇到的大坑,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03nodejs的http和https下載遠程資源post數(shù)據(jù)實例
這篇文章主要為大家介紹了nodejs的http和https下載遠程資源post數(shù)據(jù)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09Node.js對MongoDB數(shù)據(jù)庫實現(xiàn)模糊查詢的方法
模糊查詢是數(shù)據(jù)庫的基本操作之一,下面這篇文章主要給大家介紹了利用Node.js對MongoDB數(shù)據(jù)庫實現(xiàn)模糊查詢的方法教程,文中給出了詳細的介紹和示例代碼,對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-05-05使用Node.js實現(xiàn)base64和png文件相互轉(zhuǎn)換的方法
這篇文章主要介紹了使用Node.js實現(xiàn)base64和png文件相互轉(zhuǎn)換的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03nodejs使用express獲取get和post傳值及session驗證的方法
這篇文章主要介紹了nodejs使用express獲取get和post傳值及session驗證的方法,結(jié)合實例形式分析了nodejs使用express實現(xiàn)獲取get和post傳值及session驗證功能的具體操作步驟與注意事項,需要的朋友可以參考下2017-11-11