nodejs 部署方式 -pm2(一)

Author Avatar
Pang Jian 12月 02, 2016
总字数:1.3k 预计阅读:5 min
  • 在其它设备中阅读本文章

目前 Nodejs 开发中有很多痛点,其中有一个是修改完代码以后需要我们重启服务才能看到效果。这样一次次的杀进程、重启,杀进程、重启很让人头大。程序员是最痛恨重复工作的物种,之前有了解过的同学可能知道 foreverforever 可以帮我们解决上面的问题,通过对资源变化的检测做到变化后自动重启。开发阶段我们使用 node file.js 来启动另外由于 Nodejs 的单线程,任何异常都会导致整个服务中断,这对于生产上长时间提供服务的程序来讲是不可以的,forever可以帮我们在异常后重启,保证服务一直在线,我想这也就是它名字的由来吧。但我想说的是 forever 不够“高!大!上!”。接下来我要介绍一个足够高大上的神器–pm2

简介

pm2=P(rocess) M(anager)2,是可以用于生产环境的 Nodejs 的进程管理工具,并且它内置一个负载均衡。它不仅可以保证服务不会中断一直在线,并且提供 0 秒 reload 功能,还有其他一系列进程管理、监控功能。并且使用起来非常简单。下面我将把我的使用过程分享出来,Nodejs 应用是一个基于 Express 4.x 的应用,名称是Wolverine

安装

环境清单:

  • windows7 x64
  • node v5.0.0
  • npm 3.3.6

全局安装pm2

$ npm install pm2 -g

更新

$ pm2 update

启动

以前启动 Wolverine 是利用 package.json 的 scripts 来实现的,只需要执行 npm run start 就可以启动,配置如下:

"scripts": {
    "start": "node ./bin/www",
    "debug": "node debug ./bin/www"

  },

使用 pm2 我们可以在 start 处配置成 pm2 ./bin/www, 命令后面支持加参数来实现 watch、cluster 多进程模式等功能。我不太喜欢一大串的命令,于是我使用了配置文件的方式。
Wolverine 的根目录,我创建了一个 processes.json 配置文件,配置文件内容如下,注释写的也很清楚了

{
  "apps" : [{
    "name" : "Wolverine",  // 名称
    "script": "./bin/www", // 程序入库
    "cwd": "./",           // 根目录
    "watch":[
        "bin",
        "common",
        "configs",
        "public",
        "routes",
        "views"
    ],// 需要监控的目录
    "error_file":"./logs/app-err.log",// 错误输出日志
    "out_file":"./logs/app-out.log",  // 日志
    "log_date_format":"YYYY-MM-DD HH:mm Z" // 日期格式
    }]
}

随后,我在 package.json 中增加了一条

"pm2": "pm2 start processes.json"

在启动就直接输入如下命令就好:

$ npm run pm2

看到下面的界面,就启动成功了,然后我们就可以关掉这个窗口了,服务不会因此停止,是不是高大上多了。
pm2 启动界面

管理和监控

启动成功的界面会展示 App name 和 id,这两个值很重要。当然这两个值都可以在 processes.json 配置文件进行配置。
打开命令行,在任何路径下,输入

$ pm2 list

就能看到启动时的图表界面,方便我们查看所有通过 pm2 管理的 Nodejs 服务。

输入, 下面命令配合 id 或者 name 可以查看某一个进程的详细信息

$ pm2 show Wolverine 或者
$ pm2 show 0

pm2 list
内容涉及重启次数、运行时间、脚本路径、参数、日志路径、运行模式等等信息
输入

$ pm2 monit

停止、重启等命令

$ pm2 stop [app-name|id]  #停止某一个进程,可以使用 app-name 或者 id
$ pm2 stop all            #停止所有进程

$ pm2 restart all         #重启所有的进程

$ pm2 delete [app-name|id]# 删除并停止进程
$ pm2 delete all          #删除并停止所有进程

可以进一步查看每一个服务的 cpu、内存动态占用情况。
pm2 monit

日志监控

如果你一直使用 tail -f log_file.log log_error.log 来查看日志,你可能会爱上下面的这个功能。

$ pm2 logs
$ pm2 logs [app-name]

我们可以实时查看全部进程的日志,或者只查看某一个。我们甚至可以使用 json 格式查看日志。

$ pm2 logs --json

Web API

如果你不仅仅想监控被 pm2 管理的进程,还需要监控进程所运行的机器的信息,你可以使用下面这个 API

$ pm2 web

pm2 会启动一个叫做 pm2-http-interface 的进程提供 web 服务。你打开浏览器输入 http://127.0.0.1:9615,是不是被看到的结果惊艳到了。
pm2-webapi
pm2 提供的 web api 通过 json 输出了很多信息。大致结构可以看截图:
pm2-webapi-json

拿出你的想象力,我们可以开发一个应用来调用此 api,就可以开发出一个图形界面的监控软件了。。。

其它

pm2 的优势和功能还不止这些,后续还会有文章详述更多高级的用法,比如进程恢复、图形界面,模块,甚至的功能开发。最重要的优势我想就是它的稳定性了,pm2 的功能全部通过了测试,有超过 1000 个测试。同时提供 Windows、MacOSX(OSX)、Linux 的稳定版本。PayPal、微软、IBM 等等大厂都在使用。我们已经有充分的理由把它应用到生产环境上。
EOF

Documentation licensed under CC BY-SA 4.0.
本文链接:https://www.pangjian.me/2016/12/02/deploy-nodejs-pm2-1/