>  기사  >  웹 프론트엔드  >  NodeJS 상위 프로세스와 하위 프로세스 자원 공유 원칙 및 구현 방법

NodeJS 상위 프로세스와 하위 프로세스 자원 공유 원칙 및 구현 방법

亚连
亚连원래의
2018-05-29 17:40:231647검색

이 글에서는 주로 NodeJS 부모 프로세스와 자식 프로세스 간 리소스 공유의 원리와 구현 방법을 소개하고, 부모 프로세스와 자식 프로세스 간 리소스 공유를 실현하기 위한 클러스터 모듈 기반의 nodejs 관련 운영 기술을 예시 형식으로 분석합니다. 도움이 필요한 친구들이 참고할 수 있습니다

이 글에서는 NodeJS 상위 프로세스와 하위 프로세스 간 자원 공유의 원리와 구현 방법을 예시를 통해 설명합니다. 참조를 위해 모든 사람과 공유합니다. 세부 사항은 다음과 같습니다.

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

모듈 사용: cluster

소개: 노드 클러스터 구축, 멀티 프로세스 구현, child_process를 사용하여 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);
}

위 내용은 제가 모든 사람을 위해 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

vue 페이지 로딩 시 깜박이는 문제에 대한 솔루션

js가 ModelAndView 값을 얻는 문제에 대한 간략한 토론

vue 렌더링 중 {{}} 깜박이는 문제 및 그 문제 솔루션

위 내용은 NodeJS 상위 프로세스와 하위 프로세스 자원 공유 원칙 및 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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