为什么使用Pm2
最近,在学习使用vue.js前端框架,计划写一套前端到后端都是javascript的webapp,技术栈是vue+node+mysql; 在写的过程中,自己用node写了一个简单服务器,用来连接前端后端的数据交互; 前端:vue+vue-router+axios 后端:node 问题:因为我这个程序是在本地运行,没有放上服务器,而且我是使用了vs code 这个代码编辑器,由于只有一个终端,在运行cnpm run dev 后,就不能让我自己编写的node.js来运行了,这时我需要一个能在后台运行并且能监控我自己编写的js文件能不能运行成功的东西。 所以选择了pm2这个node进程管理器;
Pm2的使用(进程守护)
基于网上的部分教程已经比较详细了,下面是修改于豆瓣和SegmentFault 的内容;
介绍
pm2 是一个带有负载均衡功能的Node应用的进程管理器. 当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载, PM2是完美的。它非常适合IaaS结构,但不要把它用于PaaS方案(随后将开发Paas的解决方案). 备注:SaaS、PaaS和IaaS是云服务模式。
- SaaS 软件即服务,例如Google的 Gmail 邮箱服务.面向应用型用户
- PaaS 平台即服务.例如Google的GAE,面向开发型用户
- IaaS 基础架构即服务,例如亚马逊的AWS,IaaS对于不知道新推出的应用程序/网站会有多成功的创业公司来说非常有用
请参考 云服务模式:SaaS、PaaS和IaaS,哪一种适合你?
主要特性
- 内建负载均衡(使用 Node cluster 集群模块)
- 后台运行
- 0 秒停机重载,我理解大概意思是维护升级的时候不需要停机.
- 具有 Ubuntu 和 CentOS 的启动脚本
- 停止不稳定的进程(避免无限循环)
- 控制台检测
- 提供 HTTP API
- 远程控制和实时的接口 API ( Nodejs 模块,允许和 PM2 进程管理器交互 )
测试过 Nodejs v0.11/v0.10/v0.8 版本,兼容 CoffeeScript,基于 Linux 和 MacOS。
安装
–
npm install -g pm2
用法
1 | $ npm install pm2 -g # 命令行安装 pm2 |
运行进程的不同方式:
1 | $ pm2 start app.js -i max # 根据有效CPU数目启动最大进程数目 |
注意:
- 仅能用于 web 应用
- 运行于 Node 0.11.x 版本
- 运行于 cluster 模式(默认模式)
CoffeeScript:
1 | $ pm2 start my_app.coffee #这就是全部 |
PM2 准备好为产品级服务了吗?
只需要在自己的服务器上测试
1 | $ git clone https://github.com/Unitech/pm2.git |
pm2 list
:列出由 PM2 管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。
pm2 monit
:监视每个 node 进程的 CPU 和内存的使用情况。