首页 > 技术文章 > nodeJs多进程Cluster

amiezhang 2018-04-02 10:50 原文

在前端页面中,如果我们想进行多进程,我们会用到WebWorker,而在NodeJs中,我们如果想充分利用服务器核心资源,我们会用到Node中Cluster模块

直接上代码吧:

const cluster = require('cluster');
const http = require('http');
const process = require('process');
const os = require('os');

//是否为主进程,主进程才能创建子进程
if(cluster.isMaster){
  //每个核心一个进程为最佳
  for(let i=0;i<os.cpus().length;i++){
      cluster.fork();
  }
}else{
  const server = http.createServer((req,res)=>{
    res.setHeader('Content-Type','text/html;charset=utf-8');
    res.write(`#${process.pid}号进程为你服务~~`);
    res.end();
  })
  //同一个主进程和它的子进程可以共享端口,计算机会一直用同一个子进程来监听执行8088,直到第一个子进程资源被用完,再换其他进程
  server.listen(8088);
}

如果一台服务器4核心,上面这个程序就会生成1个主进程和4个子进程

推荐阅读