如何使用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 相关文章推荐
js可突破windows弹退效果代码
Aug 09 Javascript
JavaScript获取和设置CheckBox状态的简单方法
Jul 05 Javascript
用javascript实现自动输出网页文本
Jul 30 Javascript
JS实现的颜色实时渐变效果完整实例
Mar 25 Javascript
JS调用Android、Ios原生控件
Jan 06 Javascript
js排序与重组的实例讲解
Aug 28 Javascript
解决循环中setTimeout执行顺序的问题
Jun 20 Javascript
vue中如何实现pdf文件预览的方法
Jul 12 Javascript
jquery 动态遍历select 赋值的实例
Sep 12 jQuery
使用vue 国际化i18n 实现多实现语言切换功能
Oct 11 Javascript
Weex开发之地图篇的具体使用
Oct 16 Javascript
js prototype深入理解及应用实例分析
Nov 25 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
Smarty使用自定义资源的方法
2015/08/08 PHP
PHP封装的非对称加密RSA算法示例
2018/05/28 PHP
php实现登录页面的简单实例
2019/09/29 PHP
javascript 一些用法小结
2009/09/11 Javascript
理解Javascript_13_执行模型详解
2010/10/20 Javascript
jQuery实现遮罩层登录对话框
2016/12/29 Javascript
JavaScript数据类型的存储方法详解
2017/08/25 Javascript
vue 点击按钮增加一行的方法
2018/09/07 Javascript
angularJs复选框checkbox选中进行ng-show显示隐藏的方法
2018/10/08 Javascript
Node.js 进程平滑离场剖析小结
2019/01/24 Javascript
微信小程序实现打开并下载服务器上面的pdf文件到手机
2019/09/20 Javascript
js实现数字滚动特效
2019/12/16 Javascript
vue随机验证码组件的封装实现
2020/02/19 Javascript
详解webpack-dev-middleware 源码解读
2020/03/23 Javascript
vue打开新窗口并实现传参的图文实例
2021/03/04 Vue.js
[59:30]完美世界DOTA2联赛PWL S3 access vs LBZS 第二场 12.20
2020/12/23 DOTA
python正则表达式修复网站文章字体不统一的解决方法
2013/02/21 Python
Python爬虫实现网页信息抓取功能示例【URL与正则模块】
2017/05/18 Python
Python实现网站注册验证码生成类
2017/06/08 Python
python实现简单聊天应用 python群聊和点对点均实现
2017/09/14 Python
python跳过第一行快速读取文件内容的实例
2018/07/12 Python
使用Python 正则匹配两个特定字符之间的字符方法
2018/12/24 Python
GDAL 矢量属性数据修改方式(python)
2020/03/10 Python
python使用opencv resize图像不进行插值的操作
2020/07/05 Python
Python在后台自动解压各种压缩文件的实现方法
2020/11/10 Python
通过canvas转换颜色为RGBA格式及性能问题的解决
2019/11/22 HTML / CSS
自然健康的概念:Natural Healthy Concepts
2020/01/26 全球购物
材料化学应届生求职信
2013/10/09 职场文书
简历中个人求职的自我评价模板
2013/11/29 职场文书
搞笑创意广告语
2014/03/17 职场文书
2015年毕业实习工作总结
2015/05/29 职场文书
2015秋季运动会通讯稿
2015/07/18 职场文书
老乡会致辞
2015/07/28 职场文书
中学教师教学工作总结
2015/08/13 职场文书
Nginx配置SSL证书出错解决方案
2021/03/31 Servers
JavaScript嵌入百度地图API的最详细方法
2021/04/16 Javascript