[特殊字符] PM2 入门实战:从 0 到线上托管 React SPA

1. 什么是 PM2?(30 s 速读)

PM2 是 Node.js 的生产级进程管理器 ,内置负载均衡、日志切割、开机自启、监控面板

一句话:让你的 Node / 静态站点"永远在线"


2. 本文目标

  1. 了解 PM2 核心能力
  2. 用一条命令把 React 单页应用跑在 3000 端口
  3. 配置 ecosystem 文件,实现"可重复、可回滚"的部署
  4. 开机自启 + 日志轮转,达到线上最低可维护标准

3. 环境准备

项目 版本
OS OpenCloudOS / CentOS 8+
Node 22.11.0(已预装)
构建产物 react-app/build/ 目录已存在

4. 一条命令体验 PM2

bash 复制代码
cd /www/wwwroot/react-app
pm2 serve build 3000 --spa --name "react-app"
  • --spa:所有 404 重定向到 index.html,支持 React-Router
  • --name:进程别名,方便后续管理

成功后会看到:

text 复制代码
[PM2] Serving /www/wwwroot/react-app/build on port 3000
┌────┬─────────────┬────────────┬──────┬──────┬────────┬───┬────────┬───┐
│ id │ name        │ namespace  │ mode │ pid  │ status │ ↑ │ cpu    │ mem │
├────┼─────────────┼────────────┼──────┼──────┼────────┼───┼────────┼───┤
│ 0  │ react-app   │ default    │ fork │ xxxx │ online │ 0 │ 0%     │ 32M │
└────┴─────────────┴────────────┴──────┴──────┴────────┴───┴────────┴───┘

浏览器访问 http://<服务器IP>:3000 即可看到 React 页面。


5. 核心概念图解(Mermaid)

5.1 PM2 架构一览

start/reload CLI PM2 Daemon Process Container 1 Process Container 2 ... Log File dump.pm2 systemd

5.2 静态 SPA 流程

用户 Nginx(可选) PM2 serve build/index.html 80/443 3000 SPA 模式 200 + React 页面 用户 Nginx(可选) PM2 serve build/index.html


6. 把"命令"升级成"代码"------ecosystem 文件

在项目根新建 ecosystem.config.js

js 复制代码
module.exports = {
  apps: [{
    name: "react-app",
    script: "serve",
    args: "-s build -l 3000",
    instances: 1,
    exec_mode: "fork",
    env: { NODE_ENV: "production" },
    log_date_format: "YYYY-MM-DD HH:mm:ss Z",
    out_file: "./logs/combined.log",
    error_file: "./logs/combined.log",
    merge_logs: true
  }]
};

启动/重载:

bash 复制代码
pm2 start ecosystem.config.js
pm2 reload ecosystem.config.js        # 0 中断更新

7. 日志切割 & 磁盘保护

bash 复制代码
pm2 install pm2-logrotate
pm2 set pm2-logrotate:max_size 50M
pm2 set pm2-logrotate:retain 7

50 MB 自动切,保留 7 份,再也不怕磁盘爆。


8. 开机自启(systemd)

bash 复制代码
pm2 save                           # 保存当前列表
pm2 startup systemd                # 生成 systemd 服务
# 按提示执行
systemctl enable pm2-root

重启机器后 pm2 ls 仍在,进程自动拉回。


9. 日常值班 6 大宝命令

任务 命令
看列表 pm2 ls
实时日志 pm2 log react-app --lines 50
资源监控 pm2 monit
平滑重载 pm2 reload react-app
停止并删除 pm2 delete react-app
保存现场 pm2 save

10. 小结 & 下一步

  1. 你已拥有可重复部署的 ecosystem 文件
  2. 日志切割 + 开机自启,达到线上最低可维护标准
  3. 下一步:
    • Nginx 反向代理 80/443
    • 接入 CI/CD(GitLab/GitHub Actions)一条 pm2 reload 完成上线
    • 使用 pm2-io-apm 接入 Web 监控 & 邮件/钉钉告警

11. 一键 cheatsheet(保存即可)

markdown 复制代码
pm2 start app.js -i max      # 集群模式
pm2 reload api               # 平滑重启
pm2 monit                    # 资源面板
pm2 install pm2-logrotate    # 日志轮转
pm2 save && pm2 startup      # 开机自启

🎉 至此,PM2 入门完成!把这篇 Markdown 丢进仓库,团队其他成员也能 3 分钟跑起同样的环境。 Happy shipping!


以我之思,借AI之力

相关推荐
Java小卷34 分钟前
流程设计器为啥选择diagram-js
前端·低代码·工作流引擎
HelloReader1 小时前
Isolation Pattern(隔离模式)在前端与 Core 之间加一道“加密网关”,拦截与校验所有 IPC
前端
兆子龙2 小时前
从 float 到 Flex/Grid:CSS 左右布局简史与「刁钻」布局怎么搞
前端·架构
YukiMori232 小时前
一个有趣的原型继承实验:为什么“男人也会生孩子”?从对象赋值到构造函数继承的完整推演
前端·javascript
_哆啦A梦2 小时前
Vibe Coding 全栈专业名词清单|设计模式·基础篇(创建型+结构型核心名词)
前端·设计模式·vibecoding
百里静修2 小时前
一个 Hook 拦截所有 AJAX 请求:ajax-hooker 使用指南与原理
前端
摸鱼的春哥2 小时前
惊!黑客靠AI把墨西哥政府打穿了,海量数据被黑
前端·javascript·后端
小兵张健2 小时前
Playwright MCP 截图标注方案调研(推荐方案1)
前端·javascript·github
小兵张健3 小时前
AI 页面与交互迁移流程参考
前端·ai编程·mcp
小兵张健4 小时前
掘金发布 SOP(Codex + Playwright MCP + Edge)
前端·mcp