>  기사  >  웹 프론트엔드  >  Nodejs의 클러스터 모듈에서 여러 프로세스 간에 데이터를 공유하는 방법에 대한 문제를 해결합니다.

Nodejs의 클러스터 모듈에서 여러 프로세스 간에 데이터를 공유하는 방법에 대한 문제를 해결합니다.

高洛峰
高洛峰원래의
2016-12-07 11:40:171417검색

앞서

nodejs는 v0.6.x 이후에 모듈 클러스터를 추가하여 멀티 프로세스를 구현하고 child_process 모듈을 사용하여 프로세스를 생성 및 관리하여 멀티 코어에서 프로그램 성능을 높였습니다. CPU 머신 성능. 이번 글에서는 클러스터 모듈을 이용하여 생성된 멀티스레드가 어떻게 데이터를 공유하는지 소개하겠습니다.

프로세스 간 데이터 공유

먼저 간단한 예를 들어보겠습니다.

var cluster = require('cluster');
var data = 0;//这里定义数据不会被所有进程共享,各个进程有各自的内存区域
if (cluster.isMaster) { //主进程
 var numCPUs = require('os').cpus().length;
 for (var i = 0; i < numCPUs; i++) {
  var worker = cluster.fork();
 }
 data++;
 console.log(&#39;DATA VALUE in MainProcess: %d &#39; , data);
} else { //子进程,会被调用numCPUs次
 data++;
 console.log(&#39;DATA VALUE in ChildProcess %d: %d &#39; cluster.worker.id, data);
}

실행 결과는 다음과 같습니다.

Nodejs의 클러스터 모듈에서 여러 프로세스 간에 데이터를 공유하는 방법에 대한 문제를 해결합니다.

메인 프로세스 코드 블록과 하위 프로세스 코드 블록 외부에 변수를 선언하면 안되는 이유 전역 변수가 되나요? 대답은 '아니요'입니다. 각 프로세스는 메모리에 자신만의 영역을 갖고 있기 때문에 data++ 연산은 자신만의 영역에서 수행되는데, 이는 변수 데이터가 공유되지 않음을 의미합니다. 그렇다면 프로세스 간에 데이터를 공유하는 방법은 무엇입니까? 다음 코드를 살펴보겠습니다.

var cluster = require(&#39;cluster&#39;);
var http = require(&#39;http&#39;);
  
if (cluster.isMaster) {
 var numCPUs = require(&#39;os&#39;).cpus().length;
 var data = 0;
 // 启动多个进程.
 for (var i = 0; i < numCPUs; i++) {
 //增加一个进程
 var worker_process = cluster.fork();
 //侦听子进程的message事件
 worker_process.on(&#39;message&#39;, function(msg) {
  if (msg.cmd && msg.cmd == &#39;notifyRequest&#39;) {
  data++;
  console.log(&#39;DATA VALUE : %d &#39;, data);
  }
 });
 }
} else {
 process.send({ cmd: &#39;notifyRequest&#39; });
}

실행 결과는 다음과 같습니다.

Nodejs의 클러스터 모듈에서 여러 프로세스 간에 데이터를 공유하는 방법에 대한 문제를 해결합니다.

따라서 데이터를 공유해야 하는 경우 이 목적을 달성하려면 프로세스 간에 메시지 알림을 사용해야 합니다.


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.