⚡ 编程实验室🏗️ HTML🎨 CSS⚡ JavaScript🐍 Python🗄️ SQL☕ Java⚛️ React💚 Vue🟢 Node.js⚙️ C语言🐘 PHP🐹 Go🔷 TypeScript🐬 MySQL🔧 C++🎯 C#🦀 Rust🅱️ Bootstrap💡 jQuery🎸 Django🍃 MongoDB👗 Sass🎪 Kotlin📊 R语言📋 XML📊 Excel🐘 PostgreSQL🐳 Docker🅰️ Angular🎮 游戏🏠 网站首页

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 核心:

(实际效果因应用场景而异,IO 密集型提升明显)

动手试试

  1. 查看当前机器有几个 CPU 核心
  2. 理解主进程 fork worker,worker 运行服务
Ctrl+Enter
🚀 升级VIP
解锁全部课程+AI助手

🏆 学习排行

加载中...

📊 统计

📖 135 篇
0 完成
🔥 0