Node.js: 讓程式碼運行於多核心 CPU
本文件是快速開始指南的一部分。請在此處查看完整指南:學習如何在 Stackhero 上快速且安全地部署 Node.js 服務。
👋 歡迎來到 Stackhero 文檔!
Stackhero 提供即用型的 Node.js 雲端 解決方案,帶來多項優勢,包括:
- 只需一個簡單的
git push,即可在幾秒鐘內 部署您的應用程式。- 使用您自己的域名,並享受 HTTPS 證書的自動配置以增強安全性。
- 享受自動備份、一鍵更新,以及簡單、透明且可預測的定價,讓您高枕無憂。
- 憑藉專用的私人 VM,獲得最佳的性能和強大的安全性。
節省時間並簡化您的生活:只需 5 分鐘即可嘗試 Stackhero 的 Node.js 雲端託管 解決方案!
預設情況下,Node.js 只會使用單一核心與一個執行緒。若要善用所有可用 CPU 核心,建議使用 Node.js 的 cluster API。官方文件請參考:https://nodejs.org/api/cluster.html。
以下是一個簡單範例,建立一個使用所有 CPU 的 HTTP 伺服器:
const cluster = require('cluster');
const http = require('http');
const cpusCount = require('os').cpus().length;
if (cluster.isMaster) {
console.log(`Master ${process.pid} is running`);
// Fork workers
for (let i = 0; i < cpusCount; i++) {
cluster.fork();
}
cluster.on('exit', (worker, code, signal) => {
console.log(`Worker ${worker.process.pid} died`);
});
} else {
// Workers 會共用任何 TCP 連線,這裡是 HTTP 伺服器
http.createServer((req, res) => {
res.writeHead(200);
res.end('hello world\n');
}).listen(8000);
console.log(`Worker ${process.pid} started`);
}