如何使用pm2启动nodejs

JavaScript017

如何使用pm2启动nodejs,第1张

使用PM2来部署nodejs项目。

如果直接通过node app来启动,如果报错了可能直接停在整个运行,supervisor感觉只是拿来用作开发环境的。再网上找到pm2.目前似乎最常见的线上部署nodejs项目的有forever,pm2这两种。

使用场合:

supervisor是开发环境用。

forever管理多个站点,每个站点访问量不大,不需要监控。

pm2 网站访问量比较大,需要完整的监控界面。

PM2的主要特性:

内建负载均衡(使用Node cluster 集群模块)

后台运行

0秒停机重载,我理解大概意思是维护升级的时候不需要停机.

具有Ubuntu和CentOS 的启动脚本

停止不稳定的进程(避免无限循环)

控制台检测

提供 HTTP API

远程控制和实时的接口API ( Nodejs 模块,允许和PM2进程管理器交互 )

安装

npm install -g pm2

用法

$ npm install -g pm2         命令行全局安装pm2

$ pm2 start app.js         启动app项目

$ pm2 list                 列出由pm2管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。

作者:passerbyli

链接:http://www.jianshu.com/p/d2a640b8661c

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

1.什么是pm2: pm2是一个进程管理工具,维护一个进程列表,用它来管理node进程,负责所有运行的进程并查看node进程的状态,也支持性能监控,负载均衡等功能。

2.pm2与其他工具对比信息:其他工具拥有的特性都支持

3.特性

①后台运行:普通的启动方式 node index.js,关闭终端就结束进程,但pm2关闭终端后仍可在后端运行

②自动重启:可以监听某些文件改动,自动重启(岂不是可以利用这个来做自动部署?)

③停止不稳定的进程:限制不稳定的重启次数,到达上限就停止进程

④0秒停机重启集群模式下(什么是集群模式?),可以达到重启时不停止服务(怎么做到的)

⑤简单日志管理:pm2可以收集日志,并有插件配合管理

⑥自动负载均衡:cluster(集群)模式下,会自动使用轮询 的方式达到负载均衡,从而减轻服务器的压力

⑦提供实时的接口:pm2插件提供实时的接口,返回服务器与进程的信息

⑧集成管理:有多个进程,不同环境可以统一配置,方便管理

4.基础用法

①启动进程:pm2 start app.js

②停止/删除/重启进程:pm2 stop/delete/restart app_name|app_id|all

集群模式下,restart中断服务,而reload不会

③查看所有的进程:pm2 list/ls/status

名词解释:

1.集群模式:( Cluster 集群模式):

例如Redis上加入了cluster模式,实现了分布式存储,就是每台Redis节点上存储不同的内容

形象解释:

    单体架构:类似全栈工程师一体化服务,啥都做

    集群:也是什么都做,但是不同的是多了一个全栈工程师负担你的工作量,均匀分配,减轻压力

    高可用:当集群中其中一个服务宕机后,并不影响另一个服务的工作,只是压力会大一点,这个现象叫做高可用

    分布式:前端后端明确分工,搭配合作就叫分布式

总而言之,集群是物理形态(一般是物理集中,统一管理的)而分布式是个工作方式。

介绍UCloud内部如何利用Node.js 构建分布式集群,并分享了实践过程中走过的坑,希望对正在使用Node.js或是即将使用Node.js的朋友有一些帮助。

UCloud内部大规模使用了Node.js 技术,利用Node.js研发了一套RPC框架,主要涉及API、Web Console、服务中间层、运营报表、内部运营工具和内部系统等,解决以下四个问题:

1. 服务调动发现程序间解耦;

2. 自动快速扩容服务能力;

3. 脚本语言提高研发效率;

4. 配置集中管理变更应用自动加载。