使用pm2自动化部署node项目的方法步骤


Posted in Javascript onJanuary 28, 2019

1、pm2简介

pm2(process manager)是一个进程管理工具,维护一个进程列表,可以用它来管理你的node进程,负责所有正在运行的进程,并查看node进程的状态,也支持性能监控,负载均衡等功能。

1.1、使用pm2管理的node程序的好处

  • 监听文件变化,自动重启程序
  • 支持性能监控
  • 负载均衡
  • 程序崩溃自动重启
  • 服务器重新启动时自动重新启动
  • 自动化部署项目

 2、pm2安装与使用

 2.1、全局安装

npm install pm2 -g

2.2、常用命令

启动一个node程序

pm2 start start.js

使用pm2自动化部署node项目的方法步骤

启动进程并指定应用的程序名

pm2 start app.js --name application1

集群模式启动

// -i 表示 number-instances 实例数量
  // max 表示 PM2将自动检测可用CPU的数量 可以自己指定数量
  pm2 start start.js -i max

使用pm2自动化部署node项目的方法步骤

添加进程监视

// 在文件改变的时候会重新启动程序
  pm2 start app.js --name start --watch

使用pm2自动化部署node项目的方法步骤

列出所有进程

pm2 list
pm2 ls // 简写

从进程列表中删除进程

// pm2 delete [appname] | id
pm2 delete app // 指定进程名删除
pm2 delete 0  // 指定进程id删除

删除进程列表中所有进程

pm2 delete all

查看某个进程具体情况

pm2 describe app

使用pm2自动化部署node项目的方法步骤 

查看进程的资源消耗情况

pm2 monit

使用pm2自动化部署node项目的方法步骤

重启进程

pm2 restart app // 重启指定名称的进程
pm2 restart all // 重启所有进程

查看进程日志

pm2 logs app  // 查看该名称进程的日志
pm2 logs all  // 查看所有进程的日志

设置pm2开机自启

开启启动设置,此处是CentOS系统,其他系统替换最后一个选项(可选项:ubuntu, centos, redhat, gentoo, systemd, darwin, amazon)

pm2 startup centos

然后按照提示需要输入的命令进行输入

最后保存设置

pm2 save

3、通过pm2配置文件来自动部署项目

确保服务器安装了pm2,没有安装的话先安装

npm install pm2 -g

3.1 在项目根目录下新建一个 deploy.yaml 文件

# deploy.yaml
apps:
 - script: ./start.js    # 入口文件
  name: 'app'       # 程序名称
  env:           # 环境变量
   COMMON_VARIABLE: true
  env_production:
   NODE_ENV: production

deploy:           # 部署脚本
 production:        # 生产环境
  user: lentoo      # 服务器的用户名
  host: 192.168.2.166   # 服务器的ip地址
  port: 22        # ssh端口
  ref: origin/master   # 要拉取的git分支
  ssh_options: StrictHostKeyChecking=no # SSH 公钥检查
  repo: https://github.com/**.git # 远程仓库地址
  path: /home       # 拉取到服务器某个目录下
  pre-deploy: git fetch --all # 部署前执行
  post-deploy: npm install && pm2 reload deploy.yaml --env production # 部署后执行
  env:
   NODE_ENV: production

3.2、配置git的ssh免密认证

在服务器中生成rsa公钥和私钥,当前是 centos7 下进行

前提服务器要安装git,没有安装的先安装git,已安装的跳过

yum ?y install git

生成秘钥

ssh-keygen -t rsa -C xxx@xxx.com

在~/.ssh目录下有 id_rsa和 id_rsa.pub两个文件,其中id_rsa.pub文件里存放的即是公钥key。

登录到GitHub,点击右上方的头像,选择settings ,点击Add SSH key,把id_rsa.pub的内容复制到里面即可。

使用pm2自动化部署node项目的方法步骤

3.3 使用pm2部署项目

每次部署前先将本地的代码提交到远程git仓库

首次部署

pm2 deploy deploy.yaml production setup

部署完成后,既可登陆服务器查看配置的目录下是否从git上拉取了项目

再次部署

pm2 deploy deploy.yaml production upddate

3.4 该部署流程同样适用前端项目

如vue-cli的项目,自动部署到服务器,自动执行npm run build 命令,生成的dist目录,指定到nginx的静态文件目录下。

4、可能会遇到的坑

在window系统下 vscode的命令行程序,以及powershell执行部署的命令时,出现部署失败

pm2 deploy deploy.yaml production setup

使用pm2自动化部署node项目的方法步骤

解决方案:使用git命令行来执行

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用jquery等比例控制图片宽高的具体实现
Jan 28 Javascript
php is_numberic函数造成的SQL注入漏洞
Mar 10 Javascript
JavaScript中Date.toSource()方法的使用教程
Jun 12 Javascript
jQuery Validate验证框架经典大全
Sep 23 Javascript
浅析ES6的八进制与二进制整数字面量
Aug 30 Javascript
jQuery复制节点用法示例(clone方法)
Sep 08 Javascript
canvas绘制多边形
Feb 24 Javascript
vuejs响应用户事件(如点击事件)
Mar 14 Javascript
Vue中CSS动画原理的实现
Feb 13 Javascript
Vue组件之高德地图地址选择功能的实例代码
Jun 21 Javascript
微信小程序移动拖拽视图-movable-view实例详解
Aug 17 Javascript
使用axios请求时,发送formData请求的示例
Oct 29 Javascript
jQuery访问json文件中数据的方法示例
Jan 28 #jQuery
JS实现的点击按钮图片上下滚动效果示例
Jan 28 #Javascript
vue-cli3 项目从搭建优化到docker部署的方法
Jan 28 #Javascript
JavaScript 判断iPhone X Series机型的方法
Jan 28 #Javascript
JS实现二维数组元素的排列组合运算简单示例
Jan 28 #Javascript
新手快速上手webpack4打包工具的使用详解
Jan 28 #Javascript
jQuery实现的网站banner图片无缝轮播效果完整实例
Jan 28 #jQuery
You might like
受疫情影响 动画《Re从零开始的异世界生活》第二季延期至7月
2020/03/10 日漫
php的declare控制符和ticks教程(附示例)
2014/03/21 PHP
php操作xml入门之xml基本介绍及xml标签元素
2015/01/23 PHP
PHP使用mysql_fetch_row查询获得数据行列表的方法
2015/03/18 PHP
PHP单例模式与工厂模式详解
2017/08/29 PHP
jQuery源码分析-05异步队列 Deferred 使用介绍
2011/11/14 Javascript
通过javascript把图片转化为字符画
2013/10/24 Javascript
MyEclipse取消验证Js的两种方法
2013/11/14 Javascript
js中自定义方法实现停留几秒sleep
2014/07/11 Javascript
js中函数调用的两种常用方法使用介绍
2014/07/17 Javascript
jQuery中$.each使用详解
2015/01/29 Javascript
js实现图片和链接文字同步切换特效的方法
2015/02/20 Javascript
JavaScript定时显示广告代码分享
2015/03/02 Javascript
jquery使整个div区域可以点击的方法
2015/06/24 Javascript
JQuery实现简单的服务器轮询效果实例
2016/03/31 Javascript
Bootstrap弹出框modal上层的输入框不能获得焦点问题的解决方法
2016/12/13 Javascript
Node.js获取前端ajax提交的request信息
2017/02/20 Javascript
angularJS利用ng-repeat遍历二维数组的实例代码
2017/06/03 Javascript
jQuery实现获取table中鼠标click点击位置行号与列号的方法
2017/10/09 jQuery
把vue-router和express项目部署到服务器的方法
2018/02/21 Javascript
vue自定义指令用法经典实例小结
2019/03/16 Javascript
vue增加强缓存和版本号的实现方法
2019/05/01 Javascript
javascript中undefined的本质解析
2019/07/31 Javascript
解决vue-cli 打包后自定义动画未执行的问题
2019/11/12 Javascript
原生js实现购物车
2020/09/23 Javascript
[10:28]2018DOTA2国际邀请赛寻真——VGJ.S寻梦之路
2018/08/15 DOTA
Python Web框架Flask下网站开发入门实例
2015/02/08 Python
django数据库自动重连的方法实例
2019/07/21 Python
Python 实例方法、类方法、静态方法的区别与作用
2019/08/14 Python
农救科工作职责
2013/11/27 职场文书
教师旷工检讨书
2014/01/18 职场文书
社区党建工作汇报材料
2014/08/14 职场文书
流动人口婚育证明范本
2014/09/26 职场文书
补充协议书
2015/01/28 职场文书
伏羲庙导游词
2015/02/09 职场文书
致青春观后感
2015/06/09 职场文书