pm2在node中的应用

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

效果图:

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Netkiller

实操 Web Cache

实操 Web Cache 摘要 写这篇文章的原因,是我看到网上很多谈这类的文章,多是人云亦云,不求实事,误导读者。 下面文中我会一个一个做实验,并展示给你,说明...

4243
来自专栏技术碎碎念

OS存储器管理(一)

存储器的层次: 分为寄存器、主存(内存)和 辅存(外存)三个层次。 主存:高速缓冲存储器、主存储器、磁盘缓冲存储器,          主存又称为可执行存储...

3569
来自专栏云计算教程系列

如何在Ubuntu 16.04上使用Nginx的头模块实现浏览器缓存

网站加载得越快,访问者留下的可能性就越大。当网站充满了由后台加载的脚本运行的图像和交互式内容时,打开网站并不是一项简单的任务。它包括从服务器逐个请求许多不同的文...

1333
来自专栏FreeBuf

打造一款属于自己的远程控制软件(二)

前一篇文章介绍了软件的整体架构,接下来对被控端进行详细讲解,主要介绍被控端各个功能模块的关键技术以及开发过程中遇到的坑,希望对各位读者有借鉴作用。 被控端工作流...

2835
来自专栏云计算教程系列

如何在CentOS 7上使用Nginx的头模块实现浏览器缓存

网站加载得越快,访问者留下的可能性就越大。当网站充满了由后台加载的脚本运行的图像和交互式内容时,打开网站并不是一项简单的任务。它包括从服务器逐个请求许多不同的文...

750
来自专栏HTML5学堂

iframe跨域应用 - 使用iframe提交表单数据

之前我们提到了iframe跨域,今天我们在原有的基础之上进行“实例”的讲解。通过iframe跨域实现表单数据的提交。如果想了解iframe跨域,可以发送“ifr...

3695
来自专栏陈纪庚

我对let和const理解

​let和const是es6新出的两种变量声明的方式,接下来我来分别针对这两个,聊一聊。

701
来自专栏全栈架构

让node.js服务永不跪的工具PM2的安装与使用

因为node.js 是单进程,进程被杀死后整个服务就跪了,所以需要进程管理工具,但是pm2 远远不止这些。

692
来自专栏python学习路

三、Requests库的使用

requests 的底层实现其实就是 urllib3  Requests 唯一的一个非转基因的 Python HTTP 库,人类可以安全享用。 学过关于urll...

36710
来自专栏芋道源码1024

Redis 从入门到放飞(下)

Redis在实际使用过程中更多的用作缓存,然而缓存的数据一般都是需要设置生存时间的,即:到期后数据销毁。

701

扫码关注云+社区