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 相关文章推荐
接收键盘指令的脚本
Jun 26 Javascript
Web前端设计模式  制作漂亮的弹出层
Oct 29 Javascript
jquery插件star-rating.js实现星级评分特效
Apr 15 Javascript
js实现鼠标滑过文字链接色彩变化的效果
May 06 Javascript
jQuery基于图层模仿五星星评价功能的方法
May 07 Javascript
深入浅析JavaScript函数前面的加号和叹号
Jul 09 Javascript
JS实现图片剪裁并预览效果
Aug 12 Javascript
Jquery和Js获得元素标签名称的方法总结
Oct 08 Javascript
JavaScrip关于创建常量的知识点
Dec 07 Javascript
js实现京东秒杀倒计时功能
Jan 21 Javascript
JavaScript自定义超时API代码实例
Apr 30 Javascript
Vue 中获取当前时间并实时刷新的实现代码
May 12 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
PHP入门
2006/10/09 PHP
Ext.data.PagingMemoryProxy分页一次性读取数据的实现代码
2010/04/07 PHP
php根据一个给定范围和步进生成数组的方法
2015/06/19 PHP
Javascript学习笔记2 函数
2010/01/11 Javascript
ExtJs3.0中Store添加 baseParams 的Bug
2010/03/10 Javascript
css transform 3D幻灯片特效实现步骤解读
2013/03/27 Javascript
Js保留小数点的4种效果实现代码分享
2014/04/12 Javascript
js实现点击后将文字或图片复制到剪贴板的方法
2014/08/04 Javascript
Node.js异步I/O学习笔记
2014/11/04 Javascript
简单介绍JavaScript中字符串创建的基本方法
2015/07/07 Javascript
Javascript类型转换的规则实例解析
2016/02/23 Javascript
Vue.js 中的 $watch使用方法
2017/05/25 Javascript
浅谈vue引用静态资源需要注意的事项
2018/09/28 Javascript
JS实现图片切换特效
2019/12/23 Javascript
VUE UPLOAD 通过ACTION返回上传结果操作
2020/09/07 Javascript
[02:12]Dota 2 推出全新英雄—— 电炎绝手
2019/08/23 DOTA
[36:33]完美世界DOTA2联赛PWL S2 LBZS vs Forest 第二场 11.29
2020/12/02 DOTA
Python中lambda的用法及其与def的区别解析
2014/07/28 Python
CentOS 7下Python 2.7升级至Python3.6.1的实战教程
2017/07/06 Python
浅谈Pandas中map, applymap and apply的区别
2018/04/10 Python
对python中的高效迭代器函数详解
2018/10/18 Python
解决python3中的requests解析中文页面出现乱码问题
2019/04/19 Python
利用 Flask 动态展示 Pyecharts 图表数据方法小结
2019/09/04 Python
jupyter notebook 多环境conda kernel配置方式
2020/04/10 Python
浅谈tensorflow中dataset.shuffle和dataset.batch dataset.repeat注意点
2020/06/08 Python
一篇文章搞懂python的转义字符及用法
2020/09/03 Python
基于HTML5的WebGL经典3D虚拟机房漫游动画
2017/11/15 HTML / CSS
Allsole美国/加拿大:英国一家专门出售品牌鞋子的网站
2018/10/21 全球购物
公积金单位接收函
2014/01/11 职场文书
爱之链教学反思
2014/04/30 职场文书
教师批评与自我批评总结
2014/10/16 职场文书
英语邀请函范文
2015/02/02 职场文书
辞职信标准格式
2015/02/27 职场文书
遗失证明范文
2015/06/19 职场文书
什么是执行力?9个故事告诉您:成功绝非偶然!
2019/07/05 职场文书
健身房被搭讪?用python写了个小米计时器助人为乐
2021/06/08 Python