欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

NodeJS父進(jìn)程與子進(jìn)程資源共享原理與實(shí)現(xiàn)方法

 更新時(shí)間:2018年03月16日 09:38:33   作者:yessirpopesama  
這篇文章主要介紹了NodeJS父進(jìn)程與子進(jìn)程資源共享原理與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了nodejs基于cluster模塊實(shí)現(xiàn)父進(jìn)程與子進(jìn)程資源共享的相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了NodeJS父進(jìn)程與子進(jìn)程資源共享原理與實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:

實(shí)驗(yàn)?zāi)繕?biāo):實(shí)現(xiàn)父進(jìn)程與子進(jìn)程間資源共享

使用模塊:cluster

簡(jiǎn)介:建立node集群,實(shí)現(xiàn)多進(jìn)程,利用child_process來(lái)實(shí)現(xiàn)IPC,解決多核利用率,提高性能。

原理:

1 Master-worker主從模式的多進(jìn)程架構(gòu)

2 fork()復(fù)制進(jìn)程,充分利用cpu資源(根據(jù)內(nèi)核數(shù)決定)

3 每個(gè)進(jìn)程都有自己的區(qū)域,如果在各自區(qū)域內(nèi)執(zhí)行操作,資源并未共享。通過(guò)監(jiān)聽message事件和send實(shí)現(xiàn)消息傳遞,達(dá)到資源共享的效果

4  globalDataError為錯(cuò)誤的資源共享方式, globalDataSuccess為正確的資源共享方式。

實(shí)現(xiàn)代碼:

var cluster = require('cluster');
var cpus = require('os').cpus();
// 傳遞的事件名
var triggerEvent = {
    inc: 'inc',
    dec: 'dec'
}
// 錯(cuò)誤的數(shù)據(jù)共享方式
var globalDataError = 0;
if (cluster.isMaster) {
  // 正確的數(shù)據(jù)共享方式
  var globalDataSuccess = 0;
  globalDataError++;
  // 啟動(dòng)多個(gè)進(jìn)程,取決于內(nèi)核數(shù)
  for (var i = 0; i < cpus.length; i++) {
    var worker = cluster.fork();
    worker.on('message', function(msg) {
      switch (msg) {
        case triggerEvent.inc:
          globalDataSuccess++;
          console.log('globalDataSuccess = ', globalDataSuccess);
          break;
        case triggerEvent.dec:
          globalDataSuccess--;
          console.log('globalDataSuccess = ', globalDataSuccess);
          break;
      }
    });
  }
  console.log('Master globalDataError = ', globalDataError);
} else {
  globalDataError++;
  console.log('Worker globalDataError = ', globalDataError);
  process.send(triggerEvent.dec);
  process.send(triggerEvent.inc);
}

希望本文所述對(duì)大家nodejs程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • nodejs+mongodb aggregate級(jí)聯(lián)查詢操作示例

    nodejs+mongodb aggregate級(jí)聯(lián)查詢操作示例

    這篇文章主要介紹了nodejs+mongodb aggregate級(jí)聯(lián)查詢操作,結(jié)合實(shí)例形式分析了基于nodejs的mongodb數(shù)據(jù)庫(kù)級(jí)聯(lián)查詢相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • NVM切換不同版本node的實(shí)現(xiàn)步驟

    NVM切換不同版本node的實(shí)現(xiàn)步驟

    nvm是Node.js的版本管理器,可以讓我們輕松地在不同的Node.js版本之間進(jìn)行切換,本文就來(lái)介紹一下NVM切換不同版本node的實(shí)現(xiàn)步驟,感興趣的可以了解一下
    2023-12-12
  • node.js中RPC(遠(yuǎn)程過(guò)程調(diào)用)的實(shí)現(xiàn)原理介紹

    node.js中RPC(遠(yuǎn)程過(guò)程調(diào)用)的實(shí)現(xiàn)原理介紹

    這篇文章主要介紹了node.js中RPC(遠(yuǎn)程過(guò)程調(diào)用)的實(shí)現(xiàn)原理介紹,本文基于一個(gè)簡(jiǎn)單的RPC庫(kù)nodejs light_rpc實(shí)現(xiàn),需要的朋友可以參考下
    2014-12-12
  • Node端異常捕獲的實(shí)現(xiàn)方法

    Node端異常捕獲的實(shí)現(xiàn)方法

    本文主要介紹了Node端異常捕獲的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • node.js?使用process.argv獲取和處理命令行參數(shù)的操作

    node.js?使用process.argv獲取和處理命令行參數(shù)的操作

    process.argv是Node.js中用于獲取命令行參數(shù)的數(shù)組,基本使用方法是通過(guò)命令行傳遞參數(shù)并在腳本中訪問(wèn)這些參數(shù),參數(shù)可以根據(jù)需求進(jìn)行處理,也可以使用第三方庫(kù)如minimist或yargs來(lái)簡(jiǎn)化參數(shù)解析,這些工具可以幫助開發(fā)者有效地管理和使用命令行參數(shù),提高腳本的靈活性和功能性
    2024-10-10
  • node以及npm版本不對(duì)應(yīng)出錯(cuò)的完美解決方法

    node以及npm版本不對(duì)應(yīng)出錯(cuò)的完美解決方法

    最近項(xiàng)目用到了node和npm,查看一下當(dāng)前版本,發(fā)現(xiàn)有報(bào)錯(cuò),下面這篇文章主要給大家介紹了關(guān)于node以及npm版本不對(duì)應(yīng)出錯(cuò)的完美解決方法,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • Node.js從字符串生成文件流的實(shí)現(xiàn)方法

    Node.js從字符串生成文件流的實(shí)現(xiàn)方法

    這篇文章主要介紹了Node.js從字符串生成文件流的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • ExpressJS入門實(shí)例

    ExpressJS入門實(shí)例

    這篇文章主要介紹了ExpressJS入門實(shí)例,本文講解了創(chuàng)建項(xiàng)目、進(jìn)入目錄、安裝項(xiàng)目依賴的包、創(chuàng)建應(yīng)用程序、運(yùn)行程序等內(nèi)容,需要的朋友可以參考下
    2015-01-01
  • 純異步nodejs文件夾(目錄)復(fù)制功能

    純異步nodejs文件夾(目錄)復(fù)制功能

    這篇文章主要介紹了純異步nodejs文件夾(目錄)復(fù)制功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 在Linux系統(tǒng)上更新Node.js到最新版本的3種方法小結(jié)

    在Linux系統(tǒng)上更新Node.js到最新版本的3種方法小結(jié)

    這篇文章主要介紹了在Linux系統(tǒng)上更新Node.js到最新版本的3種方法,使用NVM,使用NPM,用二進(jìn)制包更新Node.js,文中有詳解更新方法,需要的朋友可以參考下
    2023-09-09

最新評(píng)論