使用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 相关文章推荐
suggestion开发小结以及对键盘事件的总结(针对中文输入法状态)
Dec 20 Javascript
javascript仿qq界面的折叠菜单实现代码
Dec 12 Javascript
jQuery将多条数据插入模态框的示例代码
Sep 25 Javascript
jQuery实现选项联动轮播效果【附实例】
Apr 19 Javascript
使用Promise解决多层异步调用的简单学习心得
May 17 Javascript
js绘制购物车抛物线动画
Nov 18 Javascript
用React实现一个完整的TodoList的示例代码
Oct 30 Javascript
Vue.js做select下拉列表的实例(ul-li标签仿select标签)
Mar 02 Javascript
vue实现添加与删除图书功能
Oct 07 Javascript
spring+angular实现导出excel的实现代码
Feb 27 Javascript
非常漂亮的js烟花效果
Mar 10 Javascript
vue-resource 拦截器interceptors使用详解
Jan 18 Vue.js
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
PHP支付系统设计与典型案例分享
2016/08/02 PHP
PHP中字符串长度的截取用法示例
2017/01/12 PHP
微信公众号实现扫码获取微信用户信息(网页授权)
2019/04/09 PHP
Yii2.0框架模型添加/修改/删除数据操作示例
2019/07/18 PHP
Laravel获取所有的数据库表及结构的方法
2019/10/10 PHP
文字幻灯片
2006/06/26 Javascript
javascript 对象定义方法 简单易学
2009/03/22 Javascript
jQueryUI的Dialog的简单封装
2010/06/07 Javascript
js中判断Object、Array、Function等引用类型对象是否相等
2012/08/29 Javascript
IE6-IE9不支持table.innerHTML的解决方法分享
2012/09/14 Javascript
自定义ExtJS控件之下拉树和下拉表格附源码
2013/10/15 Javascript
js中的布尔运算符使用介绍
2013/11/20 Javascript
45个JavaScript编程注意事项、技巧大全
2015/02/11 Javascript
分享网页检测摇一摇实例代码
2016/01/14 Javascript
AngularJS基础 ng-selected 指令简单示例
2016/08/03 Javascript
JavaScript实现左右下拉框动态增删示例
2017/03/09 Javascript
vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法
2018/01/25 Javascript
推荐一个基于Node.js的表单验证库
2019/02/15 Javascript
JavaScript中的null和undefined用法解析
2019/09/30 Javascript
electron踩坑之remote of undefined的解决
2020/10/06 Javascript
Python中的高级数据结构详解
2015/03/27 Python
Python3 replace()函数使用方法
2018/03/19 Python
django开发post接口简单案例,获取参数值的方法
2018/12/11 Python
解决python tkinter界面卡死的问题
2019/07/17 Python
pycharm修改file type方式
2019/11/19 Python
Python3 selenium 实现QQ群接龙自动化功能
2020/04/17 Python
波兰香水和化妆品购物网站:Notino.pl
2017/11/07 全球购物
Stutterheim瑞典:瑞典高级外套时装品牌
2019/06/24 全球购物
NHL官方在线商店:Shop.NHL.com
2020/05/01 全球购物
园林技术个人的自我评价
2014/01/08 职场文书
幼儿园教师工作感言
2014/02/15 职场文书
幼儿园感恩节活动总结
2015/03/24 职场文书
毕业酒会致辞
2015/07/29 职场文书
幼儿园保教工作总结2015
2015/10/15 职场文书
对Keras自带Loss Function的深入研究
2021/05/25 Python
Java中try catch处理异常示例
2021/12/06 Java/Android