以下是在Debian上配置Node.js集群的幾種方法:
curl -fsSL https://deb.nodesource.com/setup_16.x | sudo -E bash -
和sudo apt-get install -y nodejs
命令安裝。cluster-server.js
的文件,代碼為:const cluster = require('cluster');
const http = require('http');
const numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
console.log(`主進程 ${process.pid} 正在運行`);
for (let i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('exit', (worker, code, signal) => {
console.log(`工作進程 ${worker.process.pid} 已退出`);
});
} else {
http.createServer((req, res) => {
res.writeHead(200);
res.end('你好世界\n');
}).listen(8000);
console.log(`工作進程 ${process.pid} 已啟動`);
}
node cluster-server.js
。sudo npm install pm2 -g
。pm2 start app.js -i max
命令,-i max
會根據CPU核心數自動啟動相應數量的工作進程。sudo apt-get install nginx
。/etc/nginx/sites-available/default
,添加:upstream my - app {
server 127.0.0.1:3000;
server 127.0.0.1:3001;
server 127.0.0.1:3002;
}
server {
listen 80;
location / {
proxy_pass http://my - app;
}
}
sudo systemctl restart nginx
。