PM2自动部署代码步骤流程总结


Posted in Javascript onDecember 10, 2018

公司的项目需要自动部署到服务器上,在网上查询后,发现PM2自带的发布程序可以自动部署并运行。

0x01 环境条件

本地环境:window10的WSL ubuntu16.04

服务器环境:ubuntu18.04

使用PM2进行部署,可以先查看官方的文档

这里需要在本地和服务器环境上同时安装好 PM2 、git ,本地PM2可以通过git向github、gitee等仓库提交代码,同时通知服务器的PM2拉取最新的代码,并在拉取成功后运行代码。

0x02 设置本地环境与服务器环境gitee仓库ssh

本地环境

执行 ssh-keygen -t rsa -b 2048 -f pm2deploy -C "PM2 deploy ssh key"

PM2自动部署代码步骤流程总结

执行后将得到本地环境生成的ssh key

执行 ssh-agent bash --login -i

执行 ssh-add pm2deploy

PM2自动部署代码步骤流程总结

执行后将pm2deloy添加到ssh高速代理中去。

将公钥添加入gitee或github中,注意本地环境添加的是个人公钥,而服务器环境需要添加在部署公钥下

PM2自动部署代码步骤流程总结

添加成功以后,本地shell执行git -T git@gitee.com

PM2自动部署代码步骤流程总结

返回successfully后,则说明本地ssh已经部署完成。

添加config

如果你的公钥和私钥是有别名的,需要添加一个配置文件config来说明网站和密钥的对应关系

PM2自动部署代码步骤流程总结

如果有多个 ssh 账号需要配置,在 config 文件里隔行分开写就行

PM2自动部署代码步骤流程总结

服务器环境

服务器环境同理,不同的是服务器环境添加的公钥需要放在部署公钥下

PM2自动部署代码步骤流程总结

0x02 配置git

先将git origin 的地址修改成ssh的别名地址

vim /.git/config

修改origin 的中gitee.com 为别名gitee,然后保存

注意这里的别名是本地的别名gitee,但是git库需要保持一致,所以在服务器上配置的别名也为gitee,只需要配置别名即可,证书还是各有各的证书。

先到项目目录用git将刚刚创建的项目拉取下来,拉取后,我们随便部署一个测试的代码,看是否能提交进gitee
这里我使用的是node的官方测试代码

PM2自动部署代码步骤流程总结

PM2自动部署代码步骤流程总结

传输成功后,我们开始配置PM2的配置文件

0x03 配置PM2

官方说明中只需要配置好这里的ecosystem.config.js 配置文件,并且让本地环境和服务器环境可以通过ssh访问即可实现PM2自动部署

配置ssh

本地生成shh密钥

将密钥写入本地config文件中

将公钥写入到服务器环境中的authorized_keys

配置ecosystem.config.js

使用 pm2 ecosystem 自动生成ecosystem.config.js

ecosystem.config.js:
module.exports = {
    apps : [{
    name: 'test',
    script: 'test.js',

    // Options reference: https://pm2.io/doc/en/runtime/reference/ecosystem-file/
    // 远程服务器上的PM2参数配置
    args: 'one two',   //参数
    instances: 1,     //实例数量
    autorestart: true,  //自动启动:是
    watch: false,     //监视模式:否
    max_memory_restart: '1G',//如果超过内存多少后,将重启实例:1G
    env: {
     NODE_ENV: 'development'
    },
    env_production: {
     NODE_ENV: 'production'
    }
 }],

 deploy : {
  production : {
   user : '远程主机用户名',
   host : '远程主机的ssh-config中的别名',
   port : '远程主机ssh端口',
   ref : 'origin/master',//远程gitee上的分支
   repo : 'git@[gitee别名]:[git库地址]',
   path : '远程服务器上的部署路径',
   'post-deploy' : 'npm install && pm2 reload ecosystem.config.js --env production'//部署完成后的操作
  }
 }
};

配置完成后,执行 pm2 deploy production setup 初始化PM2的部署

PM2自动部署代码步骤流程总结

以后更新,执行 pm2 deploy production update,则更新新的代码并运行了。

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

Javascript 相关文章推荐
javascript 有趣而诡异的数组
Apr 06 Javascript
js 编写规范
Mar 03 Javascript
使用node.js 获取客户端信息代码分享
Nov 26 Javascript
Node.js中使用socket创建私聊和公聊聊天室
Nov 19 Javascript
JS禁止查看网页源代码的实现方法
Oct 12 Javascript
BootStrap与Select2使用小结
Feb 17 Javascript
jQuery制作全屏宽度固定高度轮播图(实例讲解)
Jul 08 jQuery
详解Webstorm 新建.vue文件支持高亮vue语法和es6语法
Oct 26 Javascript
Node.js中DNS模块学习总结
Feb 28 Javascript
vue实现多个元素或多个组件之间动画效果
Sep 25 Javascript
JS浅拷贝和深拷贝原理与实现方法分析
Feb 28 Javascript
Vue.js中该如何自己维护路由跳转记录
May 19 Javascript
vue路由前进后退动画效果的实现代码
Dec 10 #Javascript
Vue.js子组件向父组件通信的方法实例代码详解
Dec 10 #Javascript
vue 基于element-ui 分页组件封装的实例代码
Dec 10 #Javascript
JavaScript对象拷贝与赋值操作实例分析
Dec 10 #Javascript
express 项目分层实践详解
Dec 10 #Javascript
JS选取DOM元素常见操作方法实例分析
Dec 10 #Javascript
微信小程序分享海报生成的实现方法
Dec 10 #Javascript
You might like
JavaScript实现滚动栏效果的方法
2015/04/27 PHP
标准版Eclipse搭建PHP环境的详细步骤
2015/11/18 PHP
Laravel框架实现redis集群的方法分析
2017/09/14 PHP
Packer 3.0 JS压缩及混淆工具 下载
2007/05/03 Javascript
ASP.NET jQuery 实例8 (动态添加内容到DropDownList)
2012/02/03 Javascript
js 获取和设置css3 属性值的实现方法
2013/05/06 Javascript
纯js实现遮罩层效果原理分析
2014/05/27 Javascript
HTML5+setCutomValidity()函数验证表单实例分享
2015/04/24 Javascript
超级给力的JavaScript的React框架入门教程
2015/07/02 Javascript
JavaScript实现打字效果的方法
2015/07/10 Javascript
jQuery地图map悬停显示省市代码分享
2015/08/20 Javascript
学习javascript面向对象 实例讲解面向对象选项卡
2016/01/04 Javascript
jQuery添加删除DOM元素方法详解
2016/01/18 Javascript
JavaScript html5 canvas绘制时钟效果(二)
2016/03/27 Javascript
js仿百度音乐全选操作
2017/01/13 Javascript
Vue Transition实现类原生组件跳转过渡动画的示例
2017/08/19 Javascript
原生JS实现的碰撞检测功能示例
2018/05/18 Javascript
浅谈React的最大亮点之虚拟DOM
2018/05/29 Javascript
Nodejs 识别图片类型的方法
2019/08/15 NodeJs
微信小程序实现点赞业务
2021/02/10 Javascript
Vue实现todo应用的示例
2021/02/20 Vue.js
python读取注册表中值的方法
2013/04/08 Python
Python装饰器使用示例及实际应用例子
2015/03/06 Python
python运行时间的几种方法
2016/06/17 Python
详解Python开发中如何使用Hook技巧
2017/11/01 Python
Python3实现汉语转换为汉语拼音
2019/07/08 Python
python Django的web开发实例(入门)
2019/07/31 Python
Python 正则表达式爬虫使用案例解析
2019/09/23 Python
代码总结Python2 和 Python3 字符串的区别
2020/01/28 Python
纯CSS3打造属于自己的“小黄人”
2016/03/14 HTML / CSS
详解如何解决H5开发使用wx.hideMenuItems无效果不生效
2021/01/20 HTML / CSS
MAC彩妆澳洲官网:M·A·C AU
2021/01/17 全球购物
纪录片信仰观后感
2015/06/08 职场文书
学校运动会开幕词
2016/03/03 职场文书
Python基于Opencv识别两张相似图片
2021/04/25 Python
Golang中channel的原理解读(推荐)
2021/10/16 Golang