亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Nodejs-cluster模塊知識(shí)點(diǎn)總結(jié)及實(shí)例用法

 更新時(shí)間:2021年12月14日 08:33:14   作者:青燈夜游  
在本篇文章里小編給大家整理的是一篇關(guān)于Nodejs-cluster模塊知識(shí)點(diǎn)總結(jié)及實(shí)例用法,有興趣的朋友們可以跟著學(xué)習(xí)下。

面試官有時(shí)候會(huì)問(wèn)你,你給我說(shuō)下nodejs如何開(kāi)啟多進(jìn)程哇,你腦海里就應(yīng)該立刻出現(xiàn)cluster模塊,如今讓我?guī)闳ヌ接懴耤luster模塊的使用。

基本用法

Node.js默認(rèn)單進(jìn)程運(yùn)行,對(duì)于32位系統(tǒng)最高可以使用512MB內(nèi)存,對(duì)于64位最高可以使用1GB內(nèi)存。對(duì)于多核CPU的計(jì)算機(jī)來(lái)說(shuō),這樣做效率很低,因?yàn)橹挥幸粋€(gè)核在運(yùn)行,其他核都在閑置。cluster模塊就是為了解決這個(gè)問(wèn)題而提出的。

cluster模塊允許設(shè)立一個(gè)主進(jìn)程和若干個(gè)worker進(jìn)程,由主進(jìn)程監(jiān)控和協(xié)調(diào)worker進(jìn)程的運(yùn)行。worker之間采用進(jìn)程間通信交換消息,cluster模塊內(nèi)置一個(gè)負(fù)載均衡器,采用Round-robin算法協(xié)調(diào)各個(gè)worker進(jìn)程之間的負(fù)載。運(yùn)行時(shí),所有新建立的鏈接都由主進(jìn)程完成,然后主進(jìn)程再把TCP連接分配給指定的worker進(jìn)程。

var cluster = require('cluster');
var os = require('os');

if (cluster.isMaster){
for (var i = 0, n = os.cpus().length; i < n; i += 1){
cluster.fork();
}
} else {
http.createServer(function(req, res) {
res.writeHead(200);
res.end("hello world\n");
}).listen(8000);
}

上面代碼先判斷當(dāng)前進(jìn)程是否為主進(jìn)程(cluster.isMaster),如果是的,就按照CPU的核數(shù),新建若干個(gè)worker進(jìn)程;如果不是,說(shuō)明當(dāng)前進(jìn)程是worker進(jìn)程,則在該進(jìn)程啟動(dòng)一個(gè)服務(wù)器程序。

上面這段代碼有一個(gè)缺點(diǎn),就是一旦work進(jìn)程掛了,主進(jìn)程無(wú)法知道。為了解決這個(gè)問(wèn)題,可以在主進(jìn)程部署online事件和exit事件的監(jiān)聽(tīng)函數(shù)。

var cluster = require('cluster');
 
if(cluster.isMaster) {
  var numWorkers = require('os').cpus().length;
  console.log('Master cluster setting up ' + numWorkers + ' workers...');
 
  for(var i = 0; i < numWorkers; i++) {
    cluster.fork();
  }
 
  cluster.on('online', function(worker) {
    console.log('Worker ' + worker.process.pid + ' is online');
  });
 
  cluster.on('exit', function(worker, code, signal) {
    console.log('Worker ' + worker.process.pid + ' died with code: ' + code + ', and signal: ' + signal);
    console.log('Starting a new worker');
    cluster.fork();
  });
}

上面代碼中,主進(jìn)程一旦監(jiān)聽(tīng)到worker進(jìn)程的exit事件,就會(huì)重啟一個(gè)worker進(jìn)程。worker進(jìn)程一旦啟動(dòng)成功,可以正常運(yùn)行了,就會(huì)發(fā)出online事件。

worker對(duì)象

worker對(duì)象是cluster.fork()的返回值,代表一個(gè)worker進(jìn)程。

它的屬性和方法如下。

(1)worker.id

worker.id返回當(dāng)前worker的獨(dú)一無(wú)二的進(jìn)程編號(hào)。這個(gè)編號(hào)也是cluster.workers中指向當(dāng)前進(jìn)程的索引值。

(2)worker.process

所有的worker進(jìn)程都是用child_process.fork()生成的。child_process.fork()返回的對(duì)象,就被保存在worker.process之中。通過(guò)這個(gè)屬性,可以獲取worker所在的進(jìn)程對(duì)象。

(3)worker.send()

該方法用于在主進(jìn)程中,向子進(jìn)程發(fā)送信息。

if (cluster.isMaster) {
  var worker = cluster.fork();
  worker.send('hi there');
} else if (cluster.isWorker) {
  process.on('message', function(msg) {
    process.send(msg);
  });
}

上面代碼的作用是,worker進(jìn)程對(duì)主進(jìn)程發(fā)出的每個(gè)消息,都做回聲。

在worker進(jìn)程中,要向主進(jìn)程發(fā)送消息,使用process.send(message);要監(jiān)聽(tīng)主進(jìn)程發(fā)出的消息,使用下面的代碼。

process.on('message', function(message) {
  console.log(message);
});

發(fā)出的消息可以字符串,也可以是JSON對(duì)象。下面是一個(gè)發(fā)送JSON對(duì)象的例子。

worker.send({
  type: 'task 1',
  from: 'master',
  data: {
    // the data that you want to transfer
  }
});

cluster.workers對(duì)象

該對(duì)象只有主進(jìn)程才有,包含了所有worker進(jìn)程。每個(gè)成員的鍵值就是一個(gè)worker進(jìn)程對(duì)象,鍵名就是該worker進(jìn)程的worker.id屬性。

socket.on('data', function(id) {
  var worker = cluster.workers[id];
});

cluster模塊的屬性與方法

isMaster,isWorker

isMaster屬性返回一個(gè)布爾值,表示當(dāng)前進(jìn)程是否為主進(jìn)程。這個(gè)屬性由process.env.NODE_UNIQUE_ID決定,如果process.env.NODE_UNIQUE_ID為未定義,就表示該進(jìn)程是主進(jìn)程。

isWorker屬性返回一個(gè)布爾值,表示當(dāng)前進(jìn)程是否為work進(jìn)程。它與isMaster屬性的值正好相反。

fork()

fork方法用于新建一個(gè)worker進(jìn)程,上下文都復(fù)制主進(jìn)程。只有主進(jìn)程才能調(diào)用這個(gè)方法。

該方法返回一個(gè)worker對(duì)象。

kill()

kill方法用于終止worker進(jìn)程。它可以接受一個(gè)參數(shù),表示系統(tǒng)信號(hào)。

如果當(dāng)前是主進(jìn)程,就會(huì)終止與worker.process的聯(lián)絡(luò),然后將系統(tǒng)信號(hào)法發(fā)向worker進(jìn)程。如果當(dāng)前是worker進(jìn)程,就會(huì)終止與主進(jìn)程的通信,然后退出,返回0。

在以前的版本中,該方法也叫做 worker.destroy() 。

listening事件

worker進(jìn)程調(diào)用listening方法以后,“l(fā)istening”事件就傳向該進(jìn)程的服務(wù)器,然后傳向主進(jìn)程。

該事件的回調(diào)函數(shù)接受兩個(gè)參數(shù),一個(gè)是當(dāng)前worker對(duì)象,另一個(gè)是地址對(duì)象,包含網(wǎng)址、端口、地址類(lèi)型(IPv4、IPv6、Unix socket、UDP)等信息。這對(duì)于那些服務(wù)多個(gè)網(wǎng)址的Node應(yīng)用程序非常有用。

不中斷地重啟Node服務(wù)

重啟服務(wù)需要關(guān)閉后再啟動(dòng),利用cluster模塊,可以做到先啟動(dòng)一個(gè)worker進(jìn)程,再把原有的所有work進(jìn)程關(guān)閉。這樣就能實(shí)現(xiàn)不中斷地重啟Node服務(wù)。

首先,主進(jìn)程向worker進(jìn)程發(fā)出重啟信號(hào)。

workers[wid].send({type: 'shutdown', from: 'master'});

worker進(jìn)程監(jiān)聽(tīng)message事件,一旦發(fā)現(xiàn)內(nèi)容是shutdown,就退出。

process.on('message', function(message) {
  if(message.type === 'shutdown') {
    process.exit(0);
  }
});

下面是一個(gè)關(guān)閉所有worker進(jìn)程的函數(shù)。

function restartWorkers() {
  var wid, workerIds = [];
  for(wid in cluster.workers) {
    workerIds.push(wid);
  }
 
  workerIds.forEach(function(wid) {
    cluster.workers[wid].send({
      text: 'shutdown',
      from: 'master'
     });
    setTimeout(function() {
      if(cluster.workers[wid]) {
        cluster.workers[wid].kill('SIGKILL');
      }
    }, 5000);
  });
};

PM2模塊

PM2模塊是cluster模塊的一個(gè)包裝層。它的作用是盡量將cluster模塊抽象掉,讓用戶(hù)像使用單進(jìn)程一樣,部署多進(jìn)程N(yùn)ode應(yīng)用。

// app.js
var http = require('http');
 
http.createServer(function(req, res) {
  res.writeHead(200);
  res.end("hello world");
}).listen(8080);

用PM2從命令行啟動(dòng)這段代碼

$ pm2 start app.js -i 4

上面代碼的i參數(shù)告訴PM2,這段代碼應(yīng)該在cluster_mode啟動(dòng),且新建worker進(jìn)程的數(shù)量是4個(gè)。如果i參數(shù)的值是0,那么當(dāng)前機(jī)器有幾個(gè)CPU內(nèi)核,PM2就會(huì)啟動(dòng)幾個(gè)worker進(jìn)程。

如果一個(gè)worker進(jìn)程由于某種原因掛掉了,會(huì)立刻重啟該worker進(jìn)程。

# 重啟所有worker進(jìn)程
$ pm2 reload all

每個(gè)worker進(jìn)程都有一個(gè)id,可以用下面的命令查看單個(gè)worker進(jìn)程的詳情。

$ pm2 show <worker id>

關(guān)閉worker進(jìn)程的時(shí)候,可以部署下面的代碼,讓worker進(jìn)程監(jiān)聽(tīng)shutdown消息。一旦收到這個(gè)消息,進(jìn)行完畢收尾清理工作再關(guān)閉

process.on('message', function(msg) {
  if (msg === 'shutdown') {
    close_all_connections();
    delete_logs();
    server.close();
    process.exit(0);
  }
});

到此這篇關(guān)于Nodejs-cluster模塊知識(shí)點(diǎn)總結(jié)及實(shí)例用法的文章就介紹到這了,更多相關(guān)Nodejs-cluster模塊介紹內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Node.js中path模塊的resolve()和join()方法的區(qū)別

    詳解Node.js中path模塊的resolve()和join()方法的區(qū)別

    這篇文章主要介紹了詳解Node.js中path模塊的resolve()和join()方法的區(qū)別,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • 使用nodeJs來(lái)安裝less及編譯less文件為css文件的方法

    使用nodeJs來(lái)安裝less及編譯less文件為css文件的方法

    這篇文章主要介紹了使用nodeJs來(lái)安裝less及編譯less文件為css文件的方法,在文章末尾給大家補(bǔ)充介紹了通過(guò)nodejs將less文件轉(zhuǎn)為css文件的方法,具體內(nèi)容詳情大家通過(guò)本文學(xué)習(xí)吧
    2017-11-11
  • node.js中的fs.createWriteStream方法使用說(shuō)明

    node.js中的fs.createWriteStream方法使用說(shuō)明

    這篇文章主要介紹了node.js中的fs.createWriteStream方法使用說(shuō)明,本文介紹了fs.createWriteStream方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • Node.js API詳解之 V8模塊用法實(shí)例分析

    Node.js API詳解之 V8模塊用法實(shí)例分析

    這篇文章主要介紹了Node.js API詳解之 V8模塊用法,結(jié)合實(shí)例形式分析了Node.js API中V8模塊基本功能、函數(shù)、使用用法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-06-06
  • ExpressJS入門(mén)實(shí)例

    ExpressJS入門(mén)實(shí)例

    這篇文章主要介紹了ExpressJS入門(mén)實(shí)例,本文講解了創(chuàng)建項(xiàng)目、進(jìn)入目錄、安裝項(xiàng)目依賴(lài)的包、創(chuàng)建應(yīng)用程序、運(yùn)行程序等內(nèi)容,需要的朋友可以參考下
    2015-01-01
  • 為何從eggjs升級(jí)到midwayjs的原因詳解

    為何從eggjs升級(jí)到midwayjs的原因詳解

    這篇文章主要為大家介紹了為何從eggjs升級(jí)到midwayjs的原因詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • node.js實(shí)現(xiàn)上傳文件功能

    node.js實(shí)現(xiàn)上傳文件功能

    這篇文章主要為大家詳細(xì)介紹了node.js實(shí)現(xiàn)上傳文件功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶(hù)端

    Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶(hù)端

    這篇文章主要介紹了Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶(hù)端,本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2014-09-09
  • Node.js中DNS模塊學(xué)習(xí)總結(jié)

    Node.js中DNS模塊學(xué)習(xí)總結(jié)

    本篇文章給大家詳細(xì)介紹了Node.js中DNS模塊的相關(guān)知識(shí)點(diǎn),以及相關(guān)的實(shí)例代碼做了分享,有興趣的朋友參考下。
    2018-02-02
  • nodejs實(shí)現(xiàn)超簡(jiǎn)單生成二維碼的方法

    nodejs實(shí)現(xiàn)超簡(jiǎn)單生成二維碼的方法

    這篇文章主要介紹了nodejs實(shí)現(xiàn)超簡(jiǎn)單生成二維碼的方法,結(jié)合實(shí)例形式分析了nodejs基于qr-image插件生成二維碼的相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03

最新評(píng)論