前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PM2一键搞定,多台服务器同时部署发布Node.js项目!

PM2一键搞定,多台服务器同时部署发布Node.js项目!

原创
作者头像
Learn-anything.cn
发布2021-11-26 10:47:52
1.3K0
发布2021-11-26 10:47:52
举报
文章被收录于专栏:learn-anything.cn
一、使用场景

在 node.js 项目部署发布时,经常用 SSH 分别连接多台服务器,对每一台服务器都要执行 git pull 最新代码,编译启动应用的操作,操作琐碎且容易忘记其中某些操作。pm2 可以很好解决这个问题,只需一个命令就可以自动完成,还能实时监控、查看 node.js 应用的运行情况。

二、解决方案
第一步:服务器环境配置
第二步:开发机器环境配置
第三步:node.js 项目操作步骤配置
  1. 打开终端,切换到 node.js 项目根目录,执行 pm2 ecosystem , 生成配置文件 ,如下:
代码语言:txt
复制
// ecosystem.config.js
module.exports = {
    apps: [{
        script: 'index.js',
        watch: '.',
        env_production: {
            NODE_ENV: "production"
        },
        env_development: {
            NODE_ENV: "development"
        }
    }],
    
    // Deployment Configuration
    deploy: {
        production: {
            user: 'SSH_USERNAME',
            host: 'SSH_HOSTMACHINE',
            ref: 'origin/master',
            repo: 'GIT_REPOSITORY',
            path: 'DESTINATION_PATH',
            'pre-deploy-local': '',
            'post-deploy': 'npm install && pm2 reload ecosystem.config.js --env production',
            'pre-setup': ''
        }
    }
}
  1. 修改上面配置文件,为正确服务器、git相关信息;
  2. ecosystem.config.js 所在目录执行下面命令,初始化 node.js 项目 到服务器
代码语言:txt
复制
pm2 deploy production setup
// pm2 连接服务器,通知其 git clone 代码等初始化工作。
  1. 启动 或 更新 node.js 项目:
代码语言:txt
复制
pm2 deploy production --force;
// 让服务器 git pull 代码,编译后启动应用
// --force 的作用:如果服务器本地代码有改动,那么放弃改动,用git仓库最新代码更新项目。
三、deploy 命令详解
1、命令格式
代码语言:txt
复制
pm2 deploy <configuration_file> <environment> <command>
2、configuration_file

如果配置文件名是:ecosystem.config.js 或者 pm2.config.js ,上面命令可以不用写 <configuration_file>

代码语言:txt
复制
pm2 deploy production setup
// 此命令就是默认寻找 ecosystem.config.js  或  pm2.config.js  配置文件执行
3、environment

在配置文件中设定 env_productionenv_development ,就可以在执行命令时调用,把环境变量传递给node.js 项目:pm2 deploy production --force;

代码语言:txt
复制
// ecosystem.config.js
module.exports = {
    apps: [{
        script: 'index.js',
        watch: '.',
        env_production: {
            NODE_ENV: "production"
        },
        env_development: {
            NODE_ENV: "development"
        }
    }],
}
4、command
代码语言:txt
复制
setup                	run remote setup commands
update               	update deploy to the latest release
revert[n]           	revert to[n]th last deployment or 1
curr[ent]            	output current release commit
prev[ious]           	output previous release commit
exec | run < cmd > 		execute the given < cmd >
list                 	list previous deploy commits
[ref]                	deploy to[ref], the "ref" setting, or latest tag
四、其他重要事项
1、exec可以让所有服务器执行一次命令
代码语言:txt
复制
pm2 deploy production exec "pm2 reload all"
2、回滚到上一个部署版本
代码语言:txt
复制
pm2 deploy production revert 1
3、部署的几个时间点
代码语言:txt
复制
"pre-setup"         : "在setup执行前 运行的 命令或脚本",
"post-setup"        : "在代码clone完成后 执行的命令或脚本",
"pre-deploy"        : "pm2 startOrRestart ecosystem.json --env production",
"post-deploy"       : "pm2 startOrRestart ecosystem.json --env production",
"pre-deploy-local"  : "echo 'This is a local executed command'"
4、操作多台服务器,只需修改host
代码语言:txt
复制
"host" : ["212.83.163.1", "212.83.163.2", "212.83.163.3"],
五、报错
1、报错信息
代码语言:txt
复制
npm: command not found
post-deploy hook failed
Deploy failed
2、解决方案

pm2 部署时,出现上面错误,但运行 npm -v 都是正常的,原因是 pm2 的配置文件,按照下面步骤即可解决。

代码语言:txt
复制
# 1、打开终端
$ cd ~
$ nano .bashrc

# 2、把下面内容注释掉
#If not running interactively, don 't do anything
case $ - in
*
i * );;
*) return;;
esac

# 3、更新环境变量
$ source .bashrc
六、参考文档

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、使用场景
  • 二、解决方案
    • 第一步:服务器环境配置
      • 第二步:开发机器环境配置
        • 第三步:node.js 项目操作步骤配置
        • 三、deploy 命令详解
          • 1、命令格式
            • 2、configuration_file
              • 3、environment
                • 4、command
                • 四、其他重要事项
                  • 1、exec可以让所有服务器执行一次命令
                    • 2、回滚到上一个部署版本
                      • 3、部署的几个时间点
                        • 4、操作多台服务器,只需修改host
                        • 五、报错
                          • 1、报错信息
                            • 2、解决方案
                            • 六、参考文档
                            领券
                            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档