在生产环境中运行PM2和Node.js

在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利用率、内存使用量、请求/分钟等等!

广州VI设计公司https://www.houdianzi.com

日志管理

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扩展任何应用程序,并且几乎没有错误。今天的分享就到这里,希望本文能帮助到您!

posted @ 2020-11-25 13:36  浅笑·  阅读(296)  评论(0编辑  收藏  举报