>웹 프론트엔드 >JS 튜토리얼 >NodeJS 상위 프로세스와 하위 프로세스 간 리소스 공유에 대한 자세한 설명

NodeJS 상위 프로세스와 하위 프로세스 간 리소스 공유에 대한 자세한 설명

小云云
小云云원래의
2018-03-19 09:23:262001검색

이 글에서는 주로 NodeJS 부모 프로세스와 자식 프로세스 간 리소스 공유의 원리와 구현 방법을 소개하고, 부모 프로세스와 자식 프로세스 간 리소스 공유를 실현하기 위한 클러스터 모듈 기반의 nodejs 관련 운영 기술을 예시 형식으로 분석합니다. 모든 사람에게 도움이 되기를 바랍니다.

실험 목표: 상위 프로세스와 하위 프로세스 간의 리소스 공유 실현

사용 모듈: cluster

소개: 노드 클러스터 구축 및 다중 프로세스 구현, 하위 프로세스 사용 _프로세스 이를 달성하기 위해 IPC는 멀티 코어 활용을 해결하고 성능을 향상시킵니다.

원리:

1 마스터-작업자 마스터-슬레이브 모드 다중 프로세스 아키텍처

2 fork()프로세스를 복사하여 CPU 리소스를 최대한 활용합니다(코어 수에 따라 결정됨)

3 각 프로세스에는 고유한 속성이 있습니다. 자신의 영역, 해당 영역 내에서 작업을 수행하는 경우 리소스는 공유되지 않습니다. 메시지 이벤트를 듣고 전송함으로써 메시지 전달이 이루어지며 리소스 공유 효과를 얻을 수 있습니다.

4 globalDataError는 잘못된 리소스 공유 방법이고 globalDataSuccess는 올바른 리소스 공유 방법입니다.

구현 코드:


var cluster = require('cluster');
var cpus = require('os').cpus();
// 传递的事件名
var triggerEvent = {
    inc: 'inc',
    dec: 'dec'
}
// 错误的数据共享方式
var globalDataError = 0;
if (cluster.isMaster) {
  // 正确的数据共享方式
  var globalDataSuccess = 0;
  globalDataError++;
  // 启动多个进程,取决于内核数
  for (var i = 0; i < cpus.length; i++) {
    var worker = cluster.fork();
    worker.on(&#39;message&#39;, function(msg) {
      switch (msg) {
        case triggerEvent.inc:
          globalDataSuccess++;
          console.log(&#39;globalDataSuccess = &#39;, globalDataSuccess);
          break;
        case triggerEvent.dec:
          globalDataSuccess--;
          console.log(&#39;globalDataSuccess = &#39;, globalDataSuccess);
          break;
      }
    });
  }
  console.log(&#39;Master globalDataError = &#39;, globalDataError);
} else {
  globalDataError++;
  console.log(&#39;Worker globalDataError = &#39;, globalDataError);
  process.send(triggerEvent.dec);
  process.send(triggerEvent.inc);
}

위 내용은 NodeJS 상위 프로세스와 하위 프로세스 간 리소스 공유에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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