이 글에서는 주로 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('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); }
위 내용은 NodeJS 상위 프로세스와 하위 프로세스 간 리소스 공유에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!