利用PM2部署node.js项目的方法教程


Posted in Javascript onMay 10, 2017

前言

大家在开发中应该发现了,如果直接通过node app来启动,如果报错了可能直接停在整个运行,supervisor感觉只是拿来用作开发环境的。再网上找到pm2.目前似乎最常见的线上部署nodejs项目的有forever,pm2这两种。下面本文将详细介绍利用PM2部署node.js项目的方法教程,需要的朋友们下面来一起看看详细的介绍:

使用场合:

  • 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管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。

利用PM2部署node.js项目的方法教程

$ pm2 monit 监视每个node进程的CPU和内存的使用情况

利用PM2部署node.js项目的方法教程

$ 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 (http://localhost:9615)

$ 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 启动 并 生成一个配置文件

配置pm2启动文件

在项目根目录添加一个processes.json:

内容如下:

{
 "apps": [
 {
  "name": "mywork",
  "cwd": "/srv/node-app/current",
  "script": "bin/www",
  "log_date_format": "YYYY-MM-DD HH:mm Z",
  "error_file": "/var/log/node-app/node-app.stderr.log",
  "out_file": "log/node-app.stdout.log",
  "pid_file": "pids/node-geo-api.pid",
  "instances": 6,
  "min_uptime": "200s",
  "max_restarts": 10,
  "max_memory_restart": "1M",
  "cron_restart": "1 0 * * *",
  "watch": false,
  "merge_logs": true,
  "exec_interpreter": "node",
  "exec_mode": "fork",
  "autorestart": false,
  "vizion": false
 }
 ]
}

说明:

  • apps:json结构,apps是一个数组,每一个数组成员就是对应一个pm2中运行的应用
  • name:应用程序名称
  • cwd:应用程序所在的目录
  • script:应用程序的脚本路径
  • log_date_format:
  • error_file:自定义应用程序的错误日志文件
  • out_file:自定义应用程序日志文件
  • pid_file:自定义应用程序的pid文件
  • instances:
  • min_uptime:最小运行时间,这里设置的是60s即如果应用程序在60s内退出,pm2会认为程序异常退出,此时触发重启max_restarts设置数量
  • max_restarts:设置应用程序异常退出重启的次数,默认15次(从0开始计数)
  • cron_restart:定时启动,解决重启能解决的问题
  • watch:是否启用监控模式,默认是false。如果设置成true,当应用程序变动时,pm2会自动重载。这里也可以设置你要监控的文件。
  • merge_logs:
  • exec_interpreter:应用程序的脚本类型,这里使用的shell,默认是nodejs
  • exec_mode:应用程序启动模式,这里设置的是cluster_mode(集群),默认是fork
  • autorestart:启用/禁用应用程序崩溃或退出时自动重启
  • vizion:启用/禁用vizion特性(版本控制)

可以通过pm2 start processes.json来启动。

也可以把命令写在package.json里。如下:

利用PM2部署node.js项目的方法教程

通过npm run pm2来启动。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
IE6弹出“已终止操作”的解决办法
Nov 27 Javascript
Javascript MVC框架Backbone.js详解
Sep 18 Javascript
jquery背景跟随鼠标滑动导航
Nov 20 Javascript
JS简单模拟触发按钮点击功能的方法
Nov 30 Javascript
js数组常用最重要的方法
Feb 04 Javascript
JavaScript实现的简单加密解密操作示例
Jun 01 Javascript
详解性能更优越的小程序图片懒加载方式
Jul 18 Javascript
JavaScript如何获取一个元素的样式信息
Jul 29 Javascript
js实现简单的日历显示效果函数示例
Nov 25 Javascript
JavaScript实现tab栏切换效果
Mar 16 Javascript
TypeScript 使用 Tuple Union 声明函数重载
Apr 07 Javascript
ant design vue的form表单取值方法
Jun 01 Vue.js
全面解析vue中的数据双向绑定
May 10 #Javascript
利用forever和pm2部署node.js项目过程
May 10 #Javascript
javascript简单链式调用案例分析
May 10 #Javascript
Angular.JS通过指令操作DOM的方法
May 10 #Javascript
JS实现队列的先进先出功能示例
May 10 #Javascript
BootStrap的两种模态框方式
May 10 #Javascript
微信小程序之购物车功能
Sep 23 #Javascript
You might like
php数组函数序列之array_slice() - 在数组中根据条件取出一段值,并返回
2011/11/07 PHP
PHP中定义数组常量(array常量)的方法
2014/11/17 PHP
PHP实现合并discuz用户
2015/08/05 PHP
PHP+Ajax实现无刷新分页实例详解(附demo源码下载)
2016/04/07 PHP
php+html5+ajax实现上传图片的方法
2016/05/14 PHP
详解yii2使用多个数据库的案例
2017/06/16 PHP
javascript:void(0)的真正含义实例分析
2008/08/20 Javascript
JavaScript DOM学习第八章 表单错误提示
2010/02/19 Javascript
jQuery实现单行文字间歇向上滚动源代码
2013/06/02 Javascript
解析Jquery取得iframe中元素的几种方法
2013/07/04 Javascript
浅析JavaScript中的typeof运算符
2013/11/30 Javascript
javascript函数作用域学习示例(js作用域)
2014/01/13 Javascript
收集json解析的四种方法分享
2014/01/17 Javascript
AngularJS入门教程(一):静态模板
2014/12/06 Javascript
js焦点文字滚动效果代码分享
2015/08/25 Javascript
jQuery实现的淡入淡出二级菜单效果代码
2015/09/15 Javascript
jquery实现具有嵌套功能的选项卡
2016/02/12 Javascript
JavaScript学习笔记之数组的增、删、改、查
2016/03/23 Javascript
jQuery插件HighCharts实现的2D回归直线散点效果示例【附demo源码下载】
2017/03/09 Javascript
react 应用多入口配置及实践总结
2018/10/17 Javascript
vuedraggable+element ui实现页面控件拖拽排序效果
2020/07/29 Javascript
Vuex的actions属性的具体使用
2019/04/14 Javascript
[03:48]DOTA2完美大师赛主赛事第二日精彩集锦
2017/11/24 DOTA
[01:55]TI9显影之尘系列 - Evil Geniuses
2019/08/22 DOTA
python的numpy模块安装不成功简单解决方法总结
2017/12/23 Python
python用quad、dblquad实现一维二维积分的实例详解
2019/11/20 Python
python集合能干吗
2020/07/19 Python
Linux安装Python3如何和系统自带的Python2并存
2020/07/23 Python
美国领先的家居装饰和礼品商店:Kirkland’s
2017/01/30 全球购物
Ralph Lauren意大利官方网站:时尚界最负盛名的品牌之一
2018/10/18 全球购物
聚美优品的广告词
2014/03/14 职场文书
工作检讨书范文
2015/01/23 职场文书
教师远程培训心得体会
2016/01/09 职场文书
2016年世界人口日宣传活动总结
2016/04/05 职场文书
解决Tkinter中button按钮未按却主动执行command函数的问题
2021/05/23 Python
Spring Data JPA框架的核心概念和Repository接口
2022/04/28 Java/Android