Node.js Cluster — 多进程利用多核 CPU
用 cluster 模块创建多个工作进程,充分利用多核 CPU 性能 · 难度:高级 · +15XP
Cluster 模块
Node.js 默认是单线程的,一个进程只能用一个 CPU 核心。cluster 模块让你fork 多个子进程,每个进程跑在一个核心上,充分利用服务器 CPU。
工作原理
const cluster = require("cluster");
const http = require("http");
const numCPUs = require("os").cpus().length;
if (cluster.isMaster) {
// 主进程:fork 工作进程
console.log(主进程 ${process.pid} 启动);
for (let i = 0; i < numCPUs; i++) {
cluster.fork();
}
} else {
// 工作进程:运行服务器
http.createServer((req, res) => {
res.end(工作进程 ${process.pid} 响应请求);
}).listen(8000);
}
实际效果
假设你的服务器有 4 个 CPU 核心:
- 不用 cluster:只用 1 个核心,QPS ~5000
- 用 cluster fork 4 个 worker:用满 4 个核心,QPS ~18000
(实际效果因应用场景而异,IO 密集型提升明显)
动手试试
- 查看当前机器有几个 CPU 核心
- 理解主进程 fork worker,worker 运行服务