文档章节

pm2在node中的应用

c
 caiyezi
发布于 2016/11/08 20:24
字数 558
阅读 2
收藏 0

pm2 是一个带有负载均衡功能的Node应用的进程管理器,当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载, pm2是完美的。

主要特性:

  • 内建负载均衡(使用Node cluster 集群模块)
  • 后台运行
  • 0秒停机重载,我理解大概意思是维护升级的时候不需要停机
  • 具有Ubuntu和CentOS 的启动脚本
  • 停止不稳定的进程(避免无限循环)
  • 控制台检测
  • 提供 HTTP API
  • 远程控制和实时的接口API ( Nodejs 模块,允许和PM2进程管理器交互 )

安装:

npm install -g pm2

用法:

  • npm install pm2 -g # 命令行安装 pm2
  • pm2 start app.js -i 4 #后台运行pm2,启动4个app.js                # 也可以把'max' 参数传递给 start             # 正确的进程数目依赖于Cpu的核心数目
  • pm2 start app.js --name my-api # 命名进程
  • pm2 list # 显示所有进程状态
  • pm2 monit # 监视所有进程
  • pm2 logs # 显示所有进程日志
  • pm2 stop all # 停止所有进程
  • pm2 restart all # 重启所有进程
  • pm2 reload all # 0秒停机重载进程 (用于 NETWORKED 进程)
  • pm2 stop 0 # 停止指定的进程
  • pm2 restart 0 # 重启指定的进程
  • pm2 startup # 产生 init 脚本 保持进程活着
  • pm2 web # 运行健壮的 computer API endpoint
  • pm2 delete 0 # 杀死指定的进程
  • pm2 delete all # 杀死全部进程

运行进程的不同方式:

  • pm2 start app.js -i max # 根据有效CPU数目启动最大进程数目
  • pm2 start app.js -i 3 # 启动3个进程
  • pm2 start app.js -x #用fork模式启动 app.js 而不是使用 cluster
  • pm2 start app.js -x -- -a 23 # 用fork模式启动 app.js 并且传递参数 (-a 23)
  • pm2 start app.js --name serverone # 启动一个进程并把它命名为 serverone
  • pm2 stop serverone # 停止 serverone 进程
  • pm2 start app.json # 启动进程, 在 app.json里设置选项
  • pm2 start app.js -i max -- -a 23 #在--之后给 app.js 传递参数
  • pm2 start app.js -i max -e err.log -o out.log # 启动 并 生成一个配置文件
  • 你也可以执行用其他语言编写的app ( fork 模式):
  • pm2 start my-bash-script.sh -x --interpreter bash
  • pm2 start my-python-script.py -x --interpreter python

 

效果图:

 

本文转载自:http://www.cnblogs.com/vipzhou/p/4949200.html

共有 人打赏支持
c
粉丝 1
博文 108
码字总数 0
作品 0
西安
程序员
探索 PM2 Cluster 模式下 Log4js 日志丢失

Node 应用为单线程应用,JS 虽可利用异步 I/O 避免线程阻塞,但无法利用多核 CPU 的优势提升运行效率,提高吞吐量仍需多线程。Node Cluster 可产生多个工作线程共享同一 TCP 连接,主线程通过...

呆恋小喵_sunmy
08/24
0
0
TODO:Node.js pm2使用方法

TODO:Node.js pm2使用方法 pm2 是一个带有负载均衡功能的Node应用的进程管理器. 当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载, PM2是完美的。 1.使...

OneTODO
2016/11/07
31
0
通过Github与PM2部署Node应用

作者:郭一实 链接:https://zhuanlan.zhihu.com/p/20940096 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 背景 前一段时间,是通过百度云的BAE部署自...

anziguoer
2016/10/20
40
0
NodeJs进程管理神器 pm2 使用记录

简介 PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等,而且使用非常简单。 下面就对PM2进行入门性的介绍,基本涵盖了PM2的常用的功...

卟想苌亣
2017/12/05
0
1
PM2 介绍 启动Nodejs 框架Express项目

文章主要来自豆瓣上一位同学的文章:PM2 介绍,中间可能有部分修改! 介绍 PM2 是一个带有负载均衡功能的 Node 应用的进程管理器。 当你要把你的独立代码利用全部的服务器上的所有 CPU,并保...

투판시
2017/10/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

js 操作cookie

var cookie = {// 设置cookie方法set:function(key, val, time){// 获取当前时间var date = new Date();// 将date设置为n天以后的时间var expiresDays = time;//...

小丶二
11分钟前
0
0
限制root远程登录 su和sudo命令

9月21日任务 3.7 su命令 3.8 sudo命令 3.9 限制root远程登录 对于Linux而言,权限的重要性毋庸置疑!对于普通用户而言无法执行那些只有root用户才能有效的命令,导致工作无法有效进行; 系统...

robertt15
13分钟前
0
0
MQTT协议的初浅认识之通讯级别和持久会话

背景 这是我最近了解MQTT协议的最后一部分内容了,MQTT协议里面的QOS和Keep Alive是两个比较重要的内容。QOS的设置,直接影响了订阅客户端与中间件之间的消息交互行为。而Keep Alive直接影响...

亚林瓜子
15分钟前
1
0
calc

width: calc(100% - 30px); 特别注意:减号左右空格,均不能去掉。 width: calc(100% - 30px);

柴高八斗之父
23分钟前
0
0
Spring Cloud Gateway全局过滤器GlobalFilter:返回消息和重定向

Spring Cloud Gateway的全局过滤器GlobalFilter,顾名思义,声明后会对所有的请求生效,可以用来做权限控制,这里简单记录一下拦截到非法请求后如何返回自定义信息和将请求重定向到指定URL。...

夜雨寄北09
26分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部