文档章节

pm2在node中的应用

c
 caiyezi
发布于 2016/11/08 20:24
字数 558
阅读 5
收藏 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
西安
程序员
私信 提问
TODO:Node.js pm2使用方法

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

OneTODO
2016/11/07
31
0
探索 PM2 Cluster 模式下 Log4js 日志丢失

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

呆恋小喵_sunmy
08/24
0
0
通过Github与PM2部署Node应用

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

anziguoer
2016/10/20
40
0
利用Docker设置Node.js

docker是一个开源的应用容器引擎,可以为我们提供安全、可移植、可重复的自动化部署的方式。docker采用虚拟化的技术来虚拟化出应用程序的运行环境。如上图一样。docker就像一艘轮船。而轮船上...

开元中国2015
11/26
0
0
NodeJs进程管理神器 pm2 使用记录

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

卟想苌亣
2017/12/05
0
1

没有更多内容

加载失败,请刷新页面

加载更多

开源 serverless 产品原理剖析(二) - Fission

背景 本文是开源 serverless 产品原理剖析系列文章的第二篇,关于 serverless 背景知识的介绍可参考文章开源 serverless 产品原理剖析(一) - Kubeless,这里不再赘述。 Fission 简介 Fiss...

阿里云官方博客
4分钟前
0
0
Android面试整理(附答案)

面试,无非都是问上面这些问题(挺多的 - -!),聘请中高级的安卓开发会往深的去问,并且会问一延伸二。以下我先提出几点重点,是面试官基本必问的问题,请一定要去了解! 基础知识 – 四大组...

终端研发部
8分钟前
1
0
Vue 改变数组触发视图更新

Vue 改变数组触发视图更新 以下方法调用会改变原始数组 push(), pop(), shift(), unshift(), splice(), sort(), reverse()push()push() 方法可向数组的末尾添加一个或多个元素,并返回新的...

不负好时光
13分钟前
0
0
计算机系统要素 C5

本章值得一提的是组织计算机的结构。Hack 的指令和数据是分开存储的,因此它的 CPU 有两个 input: IN inM[16], // M value input (M = contents of RAM[A]) instruction[16],...

lionets
30分钟前
2
0
SpringSecurity404需要注意的地方

在使用@RequestMapping的时候路径的值如果写为("auth"),虽然用的时候前面加不加"/"没有区别,但是在配置了SpringSecurity的http.authorizeRequests().antMatchers()时就必须要注意了! 🌰1...

百萬馬力
33分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部