以下是在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。