在 Linux 上使用 Node.js 實現集群部署可以通過多種方式來完成,以下是幾種常見的方法:
cluster
模塊Node.js 的 cluster
模塊允許你創建多個工作進程來共享同一個服務器端口。這樣可以充分利用多核 CPU 的性能。
const cluster = require('cluster');
const http = require('http');
const numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
console.log(`Master ${process.pid} is running`);
// Fork workers.
for (let i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('exit', (worker, code, signal) => {
console.log(`worker ${worker.process.pid} died`);
});
} else {
// Workers can share any TCP connection
// In this case it is an HTTP server
http.createServer((req, res) => {
res.writeHead(200);
res.end('hello world\n');
}).listen(8000);
console.log(`Worker ${process.pid} started`);
}
PM2 是一個功能強大的 Node.js 進程管理器,支持集群模式。
npm install pm2 -g
pm2 start app.js -i max
-i max
參數會根據 CPU 核心數自動啟動相應數量的工作進程。
如果你需要在多個服務器上進行部署,可以使用 Docker 和 Kubernetes 來實現集群管理。
FROM node:14
WORKDIR /usr/src/app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 8000
CMD ["node", "app.js"]
docker build -t my-node-app .
docker run -d -p 8000:8000 --name my-node-app-container my-node-app
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-node-app
spec:
replicas: 3
selector:
matchLabels:
app: my-node-app
template:
metadata:
labels:
app: my-node-app
spec:
containers:
- name: my-node-app
image: my-node-app:latest
ports:
- containerPort: 8000
kubectl apply -f deployment.yaml
你可以使用 Nginx 作為反向代理來分發請求到多個 Node.js 實例。
sudo apt-get install nginx
編輯 /etc/nginx/sites-available/default
文件,添加以下內容:
upstream my-node-app {
server 127.0.0.1:8000;
server 127.0.0.1:8001;
server 127.0.0.1:8002;
}
server {
listen 80;
location / {
proxy_pass http://my-node-app;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
sudo systemctl restart nginx
通過以上幾種方法,你可以在 Linux 上實現 Node.js 的集群部署,選擇適合你項目需求的方法進行部署。