使用pm2管理nodejs

PM2 是一个 Node 进程管理工具,可以用来帮助我们更好的管理 Node 服务。PM2 具有以下几个特性:

  • 动态监控文件变动,0秒热启动
  • 对 CPU 进行负载均衡
  • 监控 CPU、内存的使用状况
  • 自动重启异常服务

使用 PM2 之前需要先进行安装:

yarn global add pm2

如果说 Nginx 是用于服务器间的负载均衡,那么 PM2 就是用于某个具体服务器之上的负载均衡,能够最大程度上帮助我们使用服务器资源,提高 Node 服务运行的性能,同时有助于提高服务的稳定性。
Node 是单线程的,因此无法充分使用服务器的 CPU,PM2 通过 Cluster 模式,能够帮助 Node 应用充分利用 CPU 资源。以下是官网的一张图片,十分形象:

配置文件

可以通过命令行直接运行 PM2,也可以提供一份配置文件。PM2 的配置文件比较简单,这里提供一份我常用的:

{
    "name":"node-app",
    "script":"app.js",
    "watch":true,
    "ignore-watch":"node_modules",
    "instances":"max",
    "exec_mode":"cluster",
    "log_date_format":"YYYY-MM-DD HH:mm Z",
    "out_file":"log/node-app.stdout.log"
}

现在我们运行 pm2 start pm2.json --watch 就可以通过 PM2 启动 Node 服务了,并且具有监控文件变化自动重启的功能。

常用命令

1.查看当前运行的服务

pm2 list

控制台上的界面如下:

2.监控服务

pm2 monit

控制台上的界面如下:

3.重启服务

pm2 restart xxx.json

4.平滑重启

pm2 reload xxx.json

5.停止所有服务

pm2 stop all

在线监控

PM2 官网提供了在线监控 Node 服务的功能,功能十分强大。该功能是付费的,普通用户只能监控一个项目,但对于平常学习使用是足够了。
要使用此项服务,首先需要到 https://keymetrics.io/ 注册一个账号。
注册之后点击登录,首次登陆可以创建一个新的 Bucket,用以监控 Node 服务:

点击按钮新建一个 Bucket,填写任务名:

创建 Bucket 后,会分配一个唯一的串号,复制相应的命令在服务器上执行即可:

执行完 pm2 link 命令后,会在控制台输出一个 URL:

在线链接地址.png

在浏览器中打开这个链接地址,就可以在线监控 Node 服务的运行情况了:

发表评论