Node.js的非阻塞I/O、異步與事件驅動介紹
1、Node.js的單線程 非阻塞 I/O 事件驅動
在 Java、PHP 或者.net 等服務器端語言中,會為每一個客戶端連接創(chuàng)建一個新的線程。
而每個線程需要耗費大約 2MB 內存。也就是說,理論上,一個 8GB 內存的服務器可以同時連接的最大用戶數(shù)為 4000 個左右。要讓 Web 應用程序支持更多的用戶,就需要增加服務器的數(shù)量,而 Web 應用程序的硬件成本當然就上升了。
Node.js 不為每個客戶連接創(chuàng)建一個新的線程, 而僅僅使用一個線程。當有用戶連接了,就觸發(fā)一個內部事件,通過非阻塞 I/O、事件驅動機制,讓 Node.js 程序宏觀上也是并行的。
使用 Node.js,一個 8GB 內存的服務器,可以同時處理超過 4 萬用戶的連接。
2、Node.js回調處理異步
//錯誤的寫法:
function getData(){
//模擬請求數(shù)據(jù)
var result='';
setTimeout
(function(){
result='這是請求到的數(shù)據(jù)'
},200);
return result;
}
console.log(getData());/*異步導致請求不到數(shù)據(jù)*/
//正確的處理異步:
function getData(callback){
//模擬請求數(shù)據(jù)
var result='';
setTimeout
(function(){
result='這是請求到的數(shù)據(jù)';
callback(result);
},200);
}
getData(function(data){
console.log(data);
})3、Node.js events模塊處理異步
Node.js 有多個內置的事件,我們可以通過引入 events 模塊,并通過實例化 EventEmitter類來綁定和監(jiān)聽事件。
// 引入 events 模塊
var events = require('events');
var EventEmitter=new events.EventEmitter(); /*實例化事件對象*/
EventEmitter.on
('toparent',function(){
console.log('接收到了廣播事件');
})
setTimeout
(function(){
console.log('廣播');
EventEmitter.emit
('toparent'); /*發(fā)送廣播*/
},1000)Node.js 事件循環(huán)
/*
Node.js 事件循環(huán):
Node.js 是單進程單線程應用程序,但是通過事件和回調支持并發(fā),所以性能非常高。
Node.js 的每一個 API 都是異步的,并作為一個獨立線程運行,使用異步函數(shù)調用,并處理并發(fā)。
Node.js 有多個內置的事件,我們可以通過引入 events 模塊,并通過實例化 EventEmitter 類來綁定和監(jiān)聽事件,
*/
// 引入 events 模塊
var events = require('events');
var EventEmitter = new events.EventEmitter();
//監(jiān)聽to_mime的廣播
EventEmitter.on('to_mime', function (data) {
console.log(data, '接收to_mime的數(shù)據(jù)');
})
//監(jiān)聽to_parent的廣播
EventEmitter.on('to_parent', function (data) {
console.log(data, '接收to_parent的數(shù)據(jù)');
//廣播to_mime事件
EventEmitter.emit('to_mime', '發(fā)送to_mime的數(shù)據(jù)')
})
setTimeout(function () {
console.log('開始廣播...');
//廣播to_parent事件
EventEmitter.emit('to_parent', '發(fā)送to_parent的數(shù)據(jù)')
}, 1000);執(zhí)行結果
開始廣播...
發(fā)送to_parent的數(shù)據(jù) 接收to_parent的數(shù)據(jù)
發(fā)送to_mime的數(shù)據(jù) 接收to_mime的數(shù)據(jù)
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
深入理解Node.js 事件循環(huán)和回調函數(shù)
這篇文章主要介紹了深入理解Node.js 事件循環(huán)和回調函數(shù),詳細的介紹Node.js 事件循環(huán)和Node.js回調函數(shù),需要學習的可以參考一下。2016-11-11
Nodejs使用dgram模塊創(chuàng)建UDP服務詳解
這篇文章主要為大家介紹了Nodejs使用dgram模塊創(chuàng)建UDP服務詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10
npm報錯:request to httpsregistry.npm.taobao.org 
這篇文章主要介紹了npm報錯:request to httpsregistry.npm.taobao.org failed, reason certificate has expired的解決方案,文中有詳細的解決方案,需要的朋友可以參考下2024-03-03
websocket實現(xiàn)Vue?3和Node.js之間的實時消息推送
使用?WebSocket?實現(xiàn)實時消息推送是一種高效的方式,可以在客戶端和服務器之間建立長連接,實現(xiàn)低延遲的雙向通信,以下是一個簡單的示例,展示如何在前端使用?Vue?3?和后端使用?Node.js?搭建一個?WebSocket?實現(xiàn)實時消息推送的應用2024-06-06
關于Sequelize連接查詢時inlude中model和association的區(qū)別詳解
這篇文章主要介紹了關于Sequelize連接查詢時inlude中model與association的區(qū)別,文中介紹的很詳細,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02
autojs的nodejs打包成品app經(jīng)驗分享
這篇文章主要為大家介紹了autojs的nodejs打包成品app經(jīng)驗分享,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01
nodeJs的安裝與npm全局環(huán)境變量的配置詳解
這篇文章主要介紹了nodeJs的安裝與npm全局環(huán)境變量的配置詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01
nodejs實現(xiàn)一個自定義的require方法的詳細流程
大家對nodejs中的require方法應該不會陌生,這個方法可以用來導入nodejs的內置模塊,自定義模塊,第三方模塊等,使用頻率非常高,那么這個方法內部是如何實現(xiàn)的呢?本篇文章就是從頭到尾拆分實現(xiàn)流程,最終實現(xiàn)一個自定義的require方法,需要的朋友可以參考下2025-03-03

