在生产环境中运行PM2和Nodejs

29次阅读

共计 2646 个字符,预计需要花费 7 分钟才能阅读完成。

在 Stream,我们构建了许多应用程序来展示我们的服务所提供的出色功能。对于几乎所有的应用程序,我们都将它们放在一个云服务器上—通常是 DigitalOcean 或 AWS EC2。

虽然维护代码库和维持它的相关性是有困难的,但我们发现,在维护应用程序时,最具挑战性的是保持它的活动和运行。

此外,由于 Node.js 是大多数后端 API 的核心语言,因此很难扩展单个线程进程; 这就是 PM2 发挥作用的地方,也是我们如此喜欢使用它的原因。

现在有很多流程管理器,最著名的是 Forever、StrongLoop 的流程管理器和 good ol ‘ SystemD。还有 PM2,下载量超过 6000 万次,GitHub 之星达到 2.5 万颗 (而且还在不断上升!) 我们喜欢 PM2,因为简单地说,它易于使用,并且可以完美的管理生产环境。

PM2 是什么呢?

PM2 是一个经过测试的,Node.js 应用程序的生产运行时和进程管理器。它还配备了内置的负载均衡器,使扩展应用程序更加容易。最重要的是,它可以在 Linux、Windows 和 MacOS 上工作。

我们使用配置文件(process.json),就可以指定要运行哪些进程以及要扩展到多少进程。启动 PM2 时,可以指定 process.json 文件,而 PM2 负责其余的事务。(更多关于???? 中的进程文件)

所有这些都意味着 PM2 允许我们永远保持 Node.js 应用程序的活跃,而且还是 0 秒停机重载,维护升级的时候不需要停机。

安装 PM2
安装 PM2 简直就是小菜一碟。首先,您需要确保 process.json 文件已经准备好进入代码,这样我们就可以开始这个过程了。如果您在 MacOS 上,是非常简单的,用 yarn 安装 PM2 就可以了。如果您在 Linux、Windows 或使用 Docker 容器(是的,它也支持 Docker),请按照这里的说明操作。如果您想知道它应该是什么样子的话,下面是一个用于 Winds 的 process_prod.json 文件的示例,这是我们的开源 rss 和播客应用程序。

{
  "apps": [
    {
      "name": "api",
      "cwd": "api/dist",
      "script": "server.js",
      "watch": false
    },
    {
      "name": "conductor",
      "cwd": "api/dist/workers",
      "script": "conductor.js",
      "watch": false
    },
    {
      "name": "rss-worker",
      "cwd": "api/dist/workers",
      "script": "rss.js",
      "instances": 2,
      "exec_mode": "cluster",
      "watch": false
    },
    {
      "name": "podcast-worker",
      "cwd": "api/dist/workers",
      "script": "podcast.js",
      "instances": 2,
      "exec_mode": "cluster",
      "watch": false
    },
    {
      "name": "og-worker",
      "cwd": "api/dist/workers",
      "script": "og.js",
      "instances": 2,
      "exec_mode": "cluster",
      "watch": false
    }
  ]
}

正如您所见,我们正在运行多个进程,而 PM2 在没有任何问题的情况下处理它们,使用 Node.js 集群 API 自动生成多个进程。

提示和技巧
对于任何应用程序(我们这里是进程管理器),最好从以前使用过它的人那里了解一些技巧。

自动重启

一旦启动,您的应用程序将永远保持活动状态,在崩溃和机器重新启动后自动重新启动 - 所有这些都只需要一个简单的命令:pm2 startup

进程管理


无论运行多少应用程序,PM2 都有一套指令,是我们可以分别管理它们各自的状态。下面是一些我们常用的一些的指令(无先后顺序):
pm2 start process_prod.json-通过进程 json 文件启动进程
pm2 ls-显示所有应用程序的列表
pm2 stop <app>-停止一个特定的应用程序
pm2 start <app>-启动一个特定的应用程序
pm2 <app> scale N-将您指定的应用程序缩放到 N 个实例(可用于扩大或缩小)
pm2 kill-杀死所有正在运行的应用程序
pm2 restart-重新启动所有正在运行的应用程序
pm2 reload-重新加载应用程序配置(当您修改应用程序的环境变量时,这很方便)

进程管理

运行指令 pm2 monit 将返回关于应用程序健康状况的丰富数据集。例如,您将看到 CPU 利用率、内存使用量、请求 / 分钟等等!

日志管理

PM2 有内置的日志管理。它汇聚里来自所有应用程序的日志数据,并将其写入单个源以供查看。您甚至可以实时跟踪日志,以查看应用程序的幕后情况。来自 PM2 的日志管理也伴随着日志循环,这一点非常重要,尤其是当应用程序频繁地输出冗长的日志时。

我经常使用三个命令,你也应该这样做:
pm2 logs—从所有运行的应用程序输出日志
pm2 logs app—仅从应用程序输出日志
pm2 flush—刷新所有日志数据,释放磁盘空间
记住,要做的最重要的事情是启用日志循环。这样做将把一个巨大的日志文件分割成许多更小的文件,这些文件对于 PM2 来说更便于管理。为此,运行以下指令:
pm2 install pm2-logrotate
有关日志管理的更多信息可以在这里找到。

如果您发现您的服务器上经常充满日志,请考虑使用集中式日志服务,如 Loggly、Papertrail 或 ELK。

最佳做法
总的来说,我喜欢遵循应用程序 The Twelve-Factor App 中列出的惯例。它们将帮助您充分利用 PM2。如果你还没有读过这份宣言,它可以归结为以下 12 条规则:

1. 在修订控制中监测一个代码基,有效利用多个代码基
2. 显式声明和隔离依赖项
3. 在环境中存储配置
4. 将支持服务视为附加资源
5. 严格分开构建和运行阶段
6. 将应用程序作为一个或多个无状态进程执行
7. 通过端口绑定导出服务
8. 通过流程模型向外扩展
9. 以快速启动和优雅的关机最大化鲁棒性
10. 保持开发、分期和生产尽可能相似
11·将日志视为事件流
12· 一次性运行管理任务

如果您遵循上面的规则,您将能够有效地使用 PM2 扩展任何应用程序,并且几乎没有错误。

今天的分享就到这里,希望本文能帮助到您!

点赞,让更多的人也能看到这篇内容(收藏不点赞,都是耍流氓 -_-)
关注公众号「新前端社区」,享受文章首发体验!
每周重点攻克一个前端技术难点。

正文完
 0