如何使用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 相关文章推荐
javascript XML数据显示为HTML一例
Dec 23 Javascript
jquery JSON的解析方式示例介绍
Jul 27 Javascript
JavaScript中的变量作用域介绍
Dec 31 Javascript
jQuery表单域选择器用法分析
Feb 10 Javascript
JavaScript中getUTCSeconds()方法的使用详解
Jun 11 Javascript
JS数组合并push与concat区别分析
Dec 17 Javascript
javascript实现滚动效果的数字时钟实例
Jul 21 Javascript
微信小程序  action-sheet详解及实例代码
Nov 09 Javascript
es6+angular1.X+webpack 实现按路由功能打包项目的示例
Aug 16 Javascript
Vue基本使用之对象提供的属性功能
Apr 30 Javascript
使用vue-cli3 创建vue项目并配置VS Code 自动代码格式化 vue语法高亮问题
May 14 Javascript
vue 组件间的通信之子组件向父组件传值的方式
Jul 29 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批量上传的实现代码
2013/06/09 PHP
Yii2超好用的日期和时间组件(值得收藏)
2016/05/05 PHP
php安装php_rar扩展实现rar文件读取和解压的方法
2016/11/17 PHP
List the Codec Files on a Computer
2007/06/11 Javascript
jQuery 扩展对input的一些操作方法
2009/10/30 Javascript
php gethostbyname获取域名ip地址函数详解
2010/01/24 Javascript
javascript测试题练习代码
2012/10/10 Javascript
jQuery+ajax中getJSON() 用法实例
2014/12/22 Javascript
Bootstrap~多级导航(级联导航)的实现效果【附代码】
2016/03/08 Javascript
基于javascript实现全屏漂浮广告
2016/03/31 Javascript
js 动态添加元素(div、li、img等)及设置属性的方法
2016/07/19 Javascript
手机Web APP如何实现分享多平台功能
2016/08/19 Javascript
微信小程序 使用picker封装省市区三级联动实例代码
2016/10/28 Javascript
JS时间控制实现动态效果的实例讲解
2017/07/31 Javascript
react实现一个优雅的图片占位模块组件详解
2017/10/30 Javascript
Vue中使用webpack别名的方法实例详解
2018/06/19 Javascript
原生JS实现自定义下拉单选选择框功能
2018/10/12 Javascript
30分钟用Node.js构建一个API服务器的步骤详解
2019/05/24 Javascript
JavaScript 斐波那契数列 倒序输出 输出100以内的质数代码实例
2019/09/11 Javascript
JS桶排序的简单理解与实现方法示例
2019/11/25 Javascript
JavaScript实现字符串与HTML格式相互转换
2020/03/17 Javascript
python读写ini文件示例(python读写文件)
2014/03/25 Python
Python编程实现二叉树及七种遍历方法详解
2017/06/02 Python
Python3.遍历某文件夹提取特定文件名的实例
2018/04/26 Python
Python利用itchat库向好友或者公众号发消息的实例
2019/02/21 Python
python调用动态链接库的基本过程详解
2019/06/19 Python
python调用webservice接口的实现
2019/07/12 Python
利用Tensorflow构建和训练自己的CNN来做简单的验证码识别方式
2020/01/20 Python
详解使用HTML5 Canvas创建动态粒子网格动画
2016/12/14 HTML / CSS
Darphin迪梵官网: 来自巴黎,植物和精油调制的护肤品牌
2016/10/11 全球购物
介绍一下MD5加密算法
2016/11/12 面试题
化学相关工作求职信
2013/10/02 职场文书
我爱幼儿园演讲稿
2014/09/11 职场文书
出纳试用期自我评价
2015/03/10 职场文书
MySQL的存储过程和相关函数
2022/04/26 MySQL
td 内容自动换行 table表格td设置宽度后文字太多自动换行
2022/12/24 HTML / CSS