在前端页面中,如果我们想进行多进程,我们会用到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个子进程