linux

Node.js 应用在 Linux 上如何实现高可用架构

小樊
56
2025-09-23 03:03:45
栏目: 编程语言

Node.js 应用在 Linux 上实现高可用架构的核心路径

1. 多进程集群化:充分利用服务器多核资源

Node.js 内置的 cluster 模块是实现高可用的基础,通过创建主进程(Master)和工作进程(Worker),让多个 Worker 共享同一端口处理请求,避免单进程瓶颈。主进程负责管理 Worker 的生命周期(如 fork 新进程、监控退出事件),当某 Worker 崩溃时,主进程可快速重启替代进程,保障服务连续性。
示例代码:

const cluster = require('cluster');
const http = require('http');
const numCPUs = require('os').cpus().length;

if (cluster.isMaster) {
  console.log(`主进程 ${process.pid} 启动`);
  // 根据 CPU 核心数 fork 工作进程
  for (let i = 0; i < numCPUs; i++) {
    cluster.fork();
  }
  cluster.on('exit', (worker, code, signal) => {
    console.log(`工作进程 ${worker.process.pid} 异常退出,正在重启...`);
    cluster.fork(); // 自动重启崩溃的 Worker
  });
} else {
  // 工作进程启动 HTTP 服务
  http.createServer((req, res) => {
    res.writeHead(200);
    res.end('Hello from Worker ' + process.pid + '\n');
  }).listen(3000);
  console.log(`工作进程 ${process.pid} 启动`);
}

这种方式可有效提升应用吞吐量(如 4 核 CPU 可同时处理 4 个请求),并为后续高可用架构奠定基础。

2. 负载均衡:分发流量到多个应用实例

通过负载均衡器将客户端请求分发到多个 Node.js 实例(集群),避免单实例过载。常用工具包括 Nginx(高性能、易配置)和 HAProxy(专业负载均衡):

负载均衡器还支持健康检查(如 Nginx 的 ngx_http_health_check_module、HAProxy 的 check 指令),自动剔除异常实例,确保流量仅分发到健康节点。

3. 进程管理与自动恢复:保障进程稳定性

使用 PM2(Node.js 进程管理器)实现进程守护、自动重启和负载均衡。PM2 不仅能管理单个应用实例,还能通过 cluster 模式启动多进程(等同于 cluster 模块的功能,但更易操作):

# 全局安装 PM2
npm install pm2 -g

# 启动应用(自动 fork 到多个 CPU 核心)
pm2 start app.js -i max

# 查看应用状态
pm2 status

# 设置开机自启动(避免服务器重启后进程丢失)
pm2 startup
pm2 save

PM2 还提供日志管理(pm2 logs)、性能监控(pm2 monit)等功能,简化运维流程。

4. 数据高可用:确保数据一致性与持久性

若应用依赖数据库或缓存,需确保数据层的高可用:

5. 监控与告警:提前发现问题

建立完善的监控体系,实时跟踪应用、服务器和数据库的状态,及时触发告警:

6. 容器化与编排:提升部署灵活性

使用 Docker 容器化 Node.js 应用,通过 Kubernetes(K8s)编排管理容器,实现自动扩缩容、滚动更新和故障转移:

7. 健康检查:确保流量分发到健康实例

在负载均衡器中配置健康检查,定期检测 Node.js 实例的可用性(如访问 /health 接口),当实例无法响应或响应超时时,自动将其从负载均衡池中剔除,避免将流量发送到故障节点。

健康检查是负载均衡的重要补充,确保流量仅分发到可用实例。

0
看了该问题的人还看了