如何使用pm2快速将项目部署到远程服务器


Posted in Javascript onMarch 12, 2019

使用背景

当我们需要将项目部署到远程线上服务器时;传统的方法可能就是:

  • 将本地代码通过ssh、ftp等方式上传到服务器;
  • 然后通过ssh登入到服务器,配置好环境;
  • 手动启动应用。

太过手动化,麻烦,操作繁琐。

现代自动化部署

环境:本地(Mac);远程服务器(CentOS)

使用工具:Git、pm2、node

需知概念:ssh秘钥登陆Github添加Deploy Keys

1、服务器环境部署

基本工具安装:git、pm2、node

2、ssh服务器免密登陆

服务器生成秘钥对

ssh-keygen -t rsa -C '1285227393@qq.com'

-t 指定密钥类型,默认即 rsa ,可以省略
-C 设置注释文字,比如邮箱,可以省略

由于使用的是百度云服务器,里面可以直接界面生成秘钥对,然后下载到本地的是一个xxx.txt文件

如何使用pm2快速将项目部署到远程服务器

. 此时登陆可以使用ssh -i xxx.txt[下载的公钥路径] name@domain

报错:

@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@ WARNING: UNPROTECTED PRIVATE KEY FILE! @
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
Permissions 0644 for 'server-key.txt' are too open.
It is required that your private key files are NOT accessible by others.
This private key will be ignored.
Load key "server-key.txt": bad permissions

大概意思就是,私钥文件不能被其他人所访问。可能考虑到如果被别人获取到,就可能对服务器安全造成影响,所以需要从新设置下秘钥文件的权限

重新设置秘钥文件权限:chmod 600 server-key.txt,取消其他用户Read权限

但是,使用ssh name@domain形式还是没法直接登入;追其原因,发现因为不是本地直接生成的秘钥对;

所以需要使用ssh-add -K ~/.ssh/xxx.txt[下载公钥文件]-K表示永久存储式,如果不使用者每次开机后需要重新ssh-add),就像是本地生成秘钥对然后部署到服务器需要将秘钥追加到ssh认证文件一个道理;

ssh name@domain可以正常免密登陆啦!(配置这种形式登陆后面pm2需要使用)

配置快捷登录(附加)

1. 进入ssh目录:cd ~/.ssh

2. 创建config文件: touch config

3. 进入config配置文件配置:vi config

Host lwh #快捷别名
HostName host #ssh服务器ip或domain
Port port #ssh服务器端口,默认为22
User root #ssh服务器用户名
IdentityFile ~/.ssh/server-key.txt #下载的私钥文件

4. :wq!保存退出

5. 完成后可以直接使用:ssh lwh 登陆

在Github上添加Deploy Keys

服务器生成秘钥

# 生成ssh key
ssh-keygen -t rsa

# 查看公钥内容
cat ~/.ssh/id_rsa.pub

复制秘钥内容,添加到Github上对应的项目仓库Settings下的Deploy keys

配置Deploy keys,使得服务器可以通过ssh拉取项目仓库;

配置pm2

配置ecosystem.config.js;具体pm2配置及基本使用介绍,戳~使用pm2配置生产环境

module.exports = {
 apps: [
  {
   name: 'back-Api',   //应用名
   script: './server/start.js',  //应用文件位置
   env: {
    //PM2_SERVE_PATH: "./apidoc",  //静态服务路径
    PM2_SERVE_PORT: 8080,  //静态服务器访问端口
    NODE_ENV: 'development' //启动默认模式
   },
   env_production : {
    PM2_SERVE_PORT: 8080,
    NODE_ENV: 'production' //使用production模式 pm2 start ecosystem.config.js --env production
   },
   instances:"max",     //将应用程序分布在所有CPU核心上,可以是整数或负数
   instance_var: "INSTANCE_ID",
   exec_mode: "cluster",
   min_uptime: "30s",
   max_restarts: 10,
   //cron_restart: "40",
   watch:[
    "server",
   ], //监听模式,不能单纯的设置为true,易导致无限重启,因为日志文件在变化,需要排除对其的监听
   merge_logs: true,     //集群情况下,可以合并日志
  }
 ],
 deploy: {
   production : {
    //配置没法提供密码,所以前面需要配置ssh免密码登录服务器
    user: 'root',           //ssh 登陆服务器用户名
    host: '100.12.102.198',       //ssh 地址服务器domain/IP
    ref: 'origin/master',       //Git远程/分支
    repo: 'git@github.com',     //git地址使用ssh地址
    path: '/liwenhui/www',    //项目存放服务器文件路径
    "post-deploy": 'npm install && pm2 reload ecosystem.config.js --env production' //部署后的动作
   }
 }
};

开始部署

pm2 deploy ecosystem.config.js production

报错

appledeMBP:back-server-api apple$ pm2 deploy ecosystem.config.js production
--> Deploying to production environment
--> on host 106.12.132.188
○ deploying origin/master
○ executing pre-deploy-local
○ hook pre-deploy
bash: 第 0 行:cd: /lwh/www/source: 没有那个文件或目录
○ fetching updates
○ full fetch
bash: 第 0 行:cd: /lwh/www/source: 没有那个文件或目录

fetch failed

Deploy failed
1

需要先初始化服务器应用:pm2 deploy ecosystem.config.js production setup

然后:pm2 deploy ecosystem.config.js production

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

Javascript 相关文章推荐
jscript之Open an Excel Spreadsheet
Jun 13 Javascript
JavaScript Date对象 日期获取函数
Dec 19 Javascript
单击按钮显示隐藏子菜单经典案例
Jan 04 Javascript
js获得指定控件输入光标的坐标兼容IE,Chrome,火狐等多种主流浏览器
May 21 Javascript
jquery序列化方法实例分析
Jun 10 Javascript
使用jquery实现仿百度自动补全特效
Jul 23 Javascript
基于jQuery实现的美观星级评论打分组件代码
Oct 30 Javascript
angularjs 中$apply,$digest,$watch详解
Oct 13 Javascript
解决Vue.js父组件$on无法监听子组件$emit触发事件的问题
Sep 12 Javascript
jQuery实现的3D版图片轮播示例【滑动轮播】
Jan 18 jQuery
使用Vue 自定义文件选择器组件的实例代码
Mar 04 Javascript
微信小程序获取公众号文章列表及显示文章的示例代码
Mar 10 Javascript
详解用Webpack与Babel配置ES6开发环境
Mar 12 #Javascript
详解微信小程序框架wepy踩坑记录(与vue对比)
Mar 12 #Javascript
javascript中数组的常用算法深入分析
Mar 12 #Javascript
详解javascript 变量提升(Hoisting)
Mar 12 #Javascript
NestJs 静态目录配置详解
Mar 12 #Javascript
JavaScript使用小插件实现倒计时的方法讲解
Mar 11 #Javascript
30分钟精通React今年最劲爆的新特性——React Hooks
Mar 11 #Javascript
You might like
PHP下判断网址是否有效的代码
2011/10/08 PHP
PHP 双链表(SplDoublyLinkedList)简介和使用实例
2015/05/12 PHP
Laravel5.* 打印出执行的sql语句的方法
2017/07/24 PHP
PHP实现正则匹配所有括号中的内容
2018/06/22 PHP
PHP正则判断一个变量是否为正整数的方法
2019/02/27 PHP
JS 强制设为首页的代码
2009/01/31 Javascript
jquery怎样实现ajax联动框(二)
2013/03/08 Javascript
jquery 动态创建元素的方式介绍及应用
2013/04/21 Javascript
JS批量操作CSS属性详细解析
2013/12/16 Javascript
JavaScript中使用Object.prototype.toString判断是否为数组
2015/04/01 Javascript
jQuery常用且重要方法汇总
2015/07/13 Javascript
JavaScript、tab切换完整版(自动切换、鼠标移入停止、移开运行)
2016/01/05 Javascript
遍历json 对象的属性并且动态添加属性的实现
2016/12/02 Javascript
自学实现angularjs依赖注入
2016/12/20 Javascript
详解JavaScript事件循环机制
2018/09/07 Javascript
uni-app从安装到卸载的入门教程
2020/05/15 Javascript
VUE使用axios调用后台API接口的方法
2020/08/03 Javascript
JavaScript常用8种数组去重代码实例
2020/09/09 Javascript
vue+openlayers绘制省市边界线
2020/12/24 Vue.js
python统计字符串中指定字符出现次数的方法
2015/04/04 Python
python 根据pid杀死相应进程的方法
2017/01/16 Python
python读取几个G的csv文件方法
2019/01/07 Python
django 自定义过滤器的实现
2019/02/26 Python
python实现四人制扑克牌游戏
2020/04/22 Python
python中如何使用虚拟环境
2020/10/14 Python
css3绘制天猫logo实现代码
2012/11/06 HTML / CSS
瑞士领先的网上超市:LeShop.ch
2018/11/14 全球购物
马来西亚户外装备商店:PTT Outdoor
2019/07/13 全球购物
大四毕业生学习总结的自我评价
2013/10/31 职场文书
建筑工程专业学生的自我评价
2013/12/25 职场文书
艺术节开幕词
2015/01/28 职场文书
遗嘱范文
2015/08/07 职场文书
中秋节随笔
2015/08/15 职场文书
2016年第32个教师节红领巾广播稿
2015/12/18 职场文书
教你用Python写一个植物大战僵尸小游戏
2021/04/25 Python
分享3个非常实用的 Python 模块
2022/03/03 Python