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

Nodejs中解決cluster模塊的多進程如何共享數(shù)據(jù)問題

 更新時間:2016年11月10日 08:44:20   作者:黃明恩  
本篇文章主要介紹了Nodejs中解決cluster模塊的多進程如何共享數(shù)據(jù)問題,有需要的可以了解一下。

前述

nodejs在v0.6.x之后增加了一個模塊cluster用于實現(xiàn)多進程,利用child_process模塊來創(chuàng)建和管理進程,增加程序在多核CPU機器上的性能表現(xiàn)。本文將介紹利用cluster模塊創(chuàng)建的多線程如何共享數(shù)據(jù)的問題。

進程間數(shù)據(jù)共享

首先舉個簡單的例子,代碼如下:

var cluster = require('cluster'); 
var data = 0;//這里定義數(shù)據(jù)不會被所有進程共享,各個進程有各自的內(nèi)存區(qū)域 
if (cluster.isMaster) { //主進程 
 var numCPUs = require('os').cpus().length; 
 for (var i = 0; i < numCPUs; i++) { 
  var worker = cluster.fork(); 
 } 
 data++; 
 console.log('DATA VALUE in MainProcess: %d ' , data);
} else { //子進程,會被調(diào)用numCPUs次 
 data++; 
 console.log('DATA VALUE in ChildProcess %d: %d ' cluster.worker.id, data);
}

運行結(jié)果如下: 

為什么我們在主進程代碼塊以及子進程代碼塊之外來聲明的變量不應(yīng)該是全局變量么?答案是否定的。因為每個進程在內(nèi)存都有各自的區(qū)域,因此data++操作是在各自的區(qū)域內(nèi)進行的,也就是說變量data沒被共享。那么怎么來在各進程之間共享數(shù)據(jù)呢?來看下面的代碼:

var cluster = require('cluster'); 
var http = require('http'); 
 
if (cluster.isMaster) { 
 var numCPUs = require('os').cpus().length; 
 var data = 0; 
 // 啟動多個進程. 
 for (var i = 0; i < numCPUs; i++) { 
 //增加一個進程 
 var worker_process = cluster.fork(); 
 //偵聽子進程的message事件 
 worker_process.on('message', function(msg) { 
  if (msg.cmd && msg.cmd == 'notifyRequest') { 
  data++; 
  console.log('DATA VALUE : %d ', data);
  } 
 }); 
 } 
} else { 
 process.send({ cmd: 'notifyRequest' }); 
}

運行結(jié)果如下:


因此如果需要共享數(shù)據(jù),需要在進程間使用消息通知來達到這個目的。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 搭建簡單的nodejs http服務(wù)器詳解

    搭建簡單的nodejs http服務(wù)器詳解

    本篇文章主要介紹了搭建簡單的nodejs服務(wù)器詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • node.js 使用ejs模板引擎時后綴換成.html

    node.js 使用ejs模板引擎時后綴換成.html

    本文給大家分享一個nodejs的小技巧,將ejs模板引擎的模板后綴改成.html的使用方法,非常的簡單實用,這里推薦給大家。
    2015-04-04
  • Postman xmysql不切換環(huán)境緩存數(shù)據(jù)到本地

    Postman xmysql不切換環(huán)境緩存數(shù)據(jù)到本地

    這篇文章主要為大家介紹了Postman xmysql不切換環(huán)境緩存數(shù)據(jù)到本地示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • nodejs開發(fā)微博實例

    nodejs開發(fā)微博實例

    本文給大家分享的是使用node.js實現(xiàn)開發(fā)微博的實例,主要是看了nodejs開發(fā)指南之后發(fā)現(xiàn)書上的代碼很多已經(jīng)不能用了,原因是express版本升級了,所以今天就嘗試著吧開發(fā)微博的實例也升下級,推薦給大家。
    2015-03-03
  • 在linux中使用包管理器安裝node.js

    在linux中使用包管理器安裝node.js

    這篇文章主要介紹了在linux中使用包管理器安裝node.js的方法以及具體安裝過程,非常詳細,推薦給大家,有需要的小伙伴參考下吧。
    2015-03-03
  • node.js中的events.emitter.listeners方法使用說明

    node.js中的events.emitter.listeners方法使用說明

    這篇文章主要介紹了node.js中的events.emitter.listeners方法使用說明,本文介紹了events.emitter.listeners 的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • Node.js的包詳細介紹

    Node.js的包詳細介紹

    這篇文章主要介紹了Node.js的包詳細介紹,Node.js的包是一個目錄,其中包含JSON格式的包說明文件package.json,Node.js的包基本遵循CommonJS規(guī)范,需要的朋友可以參考下
    2015-01-01
  • 詳解用node-images 打造簡易圖片服務(wù)器

    詳解用node-images 打造簡易圖片服務(wù)器

    本篇文章主要介紹了詳解用node-images 打造簡易圖片服務(wù)器,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • 修改npm全局安裝模式的路徑方法

    修改npm全局安裝模式的路徑方法

    今天小編就為大家分享一篇修改npm全局安裝模式的路徑方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 詳解基于node.js的腳手架工具開發(fā)經(jīng)歷

    詳解基于node.js的腳手架工具開發(fā)經(jīng)歷

    這篇文章主要介紹了詳解基于node.js的腳手架工具開發(fā)經(jīng)歷,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01

最新評論