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 相关文章推荐
jQuery实现form表单reset按钮重置清空表单功能
Dec 18 Javascript
在JavaScript中实现类的方式探讨
Aug 28 Javascript
javascript学习笔记(八)正则表达式
Oct 08 Javascript
JQuery Mobile实现导航栏和页脚
Mar 09 Javascript
深入理解JavaScript定时机制
Oct 27 Javascript
详解vue 实例方法和数据
Oct 23 Javascript
Node.js console控制台简单用法分析
Jan 04 Javascript
jQuery简单实现根据日期计算星期几的方法
Jan 09 jQuery
vue全局自定义指令-元素拖拽的实现代码
Apr 14 Javascript
使用JavaScrip模拟实现仿京东搜索框功能
Oct 16 Javascript
vue学习笔记之过滤器的基本使用方法实例分析
Feb 01 Javascript
Postman动态获取返回值过程详解
Jun 30 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实现留言板功能
2017/03/05 PHP
thinkphp5.0整合phpsocketio完整攻略(绕坑)
2018/10/12 PHP
PHP中str_split()函数的用法讲解
2019/04/11 PHP
PHP基础之输出缓冲区基本概念、原理分析
2019/06/19 PHP
Js点击弹出下拉菜单效果实例
2013/08/12 Javascript
js创建元素(节点)示例
2014/01/02 Javascript
javascript实现全角半角检测的方法
2015/07/23 Javascript
从源码里了解vue中的nextTick的使用
2018/11/22 Javascript
bootstrap 日期控件 datepicker被弹出框dialog覆盖的解决办法
2019/07/09 Javascript
解决layui的form里的元素进行动态生成,验证失效的问题
2019/09/14 Javascript
使用localStorage替代cookie做本地存储
2019/09/25 Javascript
js实现图片上传即时显示效果
2019/09/30 Javascript
JS+canvas五子棋人机对战实现步骤详解
2020/06/04 Javascript
Python实现Windows上气泡提醒效果的方法
2015/06/03 Python
python操作mysql数据库
2017/03/05 Python
Python实现图片转字符画的示例代码
2017/08/21 Python
python去除扩展名的实例讲解
2018/04/23 Python
python版大富翁源代码分享
2018/11/19 Python
python 求一个列表中所有元素的乘积实例
2019/06/11 Python
python动态视频下载器的实现方法
2019/09/16 Python
Python 日期的转换及计算的具体使用详解
2020/01/16 Python
PyQt5.6+pycharm配置以及pyinstaller生成exe(小白教程)
2020/06/02 Python
美国最受欢迎的度假租赁网站:VRBO
2016/08/02 全球购物
Canal官网:巴西女性时尚品牌
2019/10/16 全球购物
销售人员中英文自荐信
2013/09/22 职场文书
网站编辑求职信
2013/10/17 职场文书
国际贸易专业个人求职信范文分享
2013/12/14 职场文书
《黄山奇石》教学反思
2014/04/19 职场文书
给校长的建议书100字
2014/05/16 职场文书
女生节标语
2014/06/26 职场文书
争先创优公开承诺书
2014/08/30 职场文书
2015年董事长秘书工作总结
2015/07/23 职场文书
Jupyter notebook 不自动弹出网页的解决方案
2021/05/21 Python
springboot集成springCloud中gateway时启动报错的解决
2021/07/16 Java/Android
spring cloud 配置中心native配置方式
2021/09/25 Java/Android
Python绘画好看的星空图
2022/03/17 Python