大前端H5

使用 PM2 管理 Node 服务

2017-12-12  本文已影响91人  柏丘君

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

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

yarn global add pm2

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


pm2 cluster.png

配置文件

可以通过命令行直接运行 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

控制台上的界面如下:


屏幕 list.png

2.监控服务

pm2 monit

控制台上的界面如下:


pm2 monit.png

3.重启服务

pm2 restart xxx.json

4.平滑重启

pm2 reload xxx.json

5.停止所有服务

pm2 stop all

在线监控

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

首次登陆.png
点击按钮新建一个 Bucket,填写任务名:
填写名字.png
创建 Bucket 后,会分配一个唯一的串号,复制相应的命令在服务器上执行即可:
执行link命令.png
执行完 pm2 link 命令后,会在控制台输出一个 URL:
在线链接地址.png
在浏览器中打开这个链接地址,就可以在线监控 Node 服务的运行情况了:
在线监控.png

完。

上一篇下一篇

猜你喜欢

热点阅读