温馨提示×

Node.js CentOS集群如何搭建

小樊
42
2025-11-19 20:48:50
栏目: 编程语言

在CentOS上搭建Node.js集群可以通过多种方式实现,其中一种常见的方法是使用PM2(Process Manager 2)。PM2是一个功能强大的Node.js进程管理器,可以帮助你管理和监控Node.js应用程序。以下是使用PM2在CentOS上搭建Node.js集群的步骤:

前提条件

  1. 安装Node.js:确保你的CentOS系统上已经安装了Node.js。如果没有安装,可以使用以下命令安装:

    sudo yum install -y nodejs npm
    
  2. 安装PM2:使用npm全局安装PM2:

    sudo npm install -g pm2
    

搭建Node.js集群

  1. 创建Node.js应用:假设你已经有一个Node.js应用,如果没有,可以创建一个简单的示例应用。例如,创建一个名为app.js的文件,内容如下:

    const http = require('http');
    
    http.createServer((req, res) => {
      res.writeHead(200, { 'Content-Type': 'text/plain' });
      res.end('Hello World\n');
    }).listen(3000, () => {
      console.log('Server running at http://localhost:3000/');
    });
    
  2. 启动Node.js应用:使用PM2启动你的Node.js应用,并指定多个实例以实现集群模式。例如,启动4个实例:

    pm2 start app.js -i 4
    

    这里的-i 4表示启动4个实例。

  3. 查看集群状态:使用PM2查看集群状态:

    pm2 status
    
  4. 管理集群:你可以使用PM2的各种命令来管理集群,例如:

    • 停止所有实例:
      pm2 stop all
      
    • 重启所有实例:
      pm2 restart all
      
    • 删除所有实例:
      pm2 delete all
      
  5. 配置负载均衡:PM2会自动处理负载均衡,将请求分发到不同的Node.js实例。

配置Nginx反向代理(可选)

如果你希望通过Nginx来处理HTTP请求并将它们转发到Node.js集群,可以按照以下步骤进行配置:

  1. 安装Nginx

    sudo yum install -y nginx
    
  2. 配置Nginx:编辑Nginx配置文件(通常位于/etc/nginx/nginx.conf/etc/nginx/conf.d/default.conf),添加以下内容:

    http {
        upstream node_app {
            server 127.0.0.1:3000;
            server 127.0.0.1:3001;
            server 127.0.0.1:3002;
            server 127.0.0.1:3003;
        }
    
        server {
            listen 80;
    
            location / {
                proxy_pass http://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;
            }
        }
    }
    
  3. 重启Nginx

    sudo systemctl restart nginx
    

通过以上步骤,你就可以在CentOS上成功搭建一个Node.js集群,并使用PM2进行管理和监控。如果需要通过Nginx进行负载均衡,也可以按照上述步骤进行配置。

0