PM2实现远程发布
pm2是一个node的守护进程管理器
学习的原因
在开发中,调试环境的发布比较繁琐,经常要到服务器拉取代码、重新打包项目、重启服务。
而pm2可以让我在本地完成这一系列动作,大大简化发布的流程。
安装
npm install pm2 -g
简单使用
pm2 start app.js // 启动node
pm2 restart app_name|id // 重启 id 从 pm2 logs中能看到
pm2 reload app_name|id // 重载
pm2 stop app_name|id // 停止服务
pm2 delete app_name|id // 删除服务
pm2 list // 查看进程列表
pm2 logs // 日志
非常的简单
配置说明
新建ecosystem.json
{
"apps": [
{
"description": "abc",
"script": "index.js",
"name": "abc",
"instances": 1,
"exec_mode": "cluster",
"merge_logs": true,
"env": {
"NODE_ENV": "production"
}
}
],
"deploy": {
"development": {
"user": "user", // ssh的用户名
"host": ["192.168.1.2"], // 要发布的机器
"ref": "origin/develop", // 要发布的代码的分支
"repo": "git@xxx.git", // 代码的仓库
"path": "/path/to/your/app", // 服务器存储代码地址
"ssh_options": "ForwardAgent=yes", // 采用本地的私钥
"post-deploy": "yarn && yarn run build && pm2 startOrRestart ecosystem.json --env production", // 发布部署的命令
"env": {
"NODE_ENV": "production"
}
},
"prod":{
....
}
}
}
使用:
第一次
// 第一次运行 自动在/path/to/your/app中创建source文件夹 拉取代码
pm2 deploy ecosystem.json development setup
然后使用
pm2 deploy econsystem.json development
意思是使用pm2发布development环境
可能遇到的问题:
- 远程的服务器无法获取github/gitlab的代码
解决方案:
1)生成公钥并添加到github中的settings中
2)采用本地私钥"ssh_options": "ForwardAgent=yes"
3) 运行ssh-add命令
pm2踩坑(更新至20.3.3)
1. devDependencies没有安装
// 该命令不会安装devDependencies
"post-deploy": "yarn && yarn run build && pm2 startOrRestart ecosystem.json --env production", 发布部署的命令
"env": {
"NODE_ENV": "production" // 使用了production 这个时候yarn不会安装devDependencies
}
使用deploy命令时候发现没有安装devDependencies导致线上打包(webpack缺失)失败,因为pm2 deploy命令为非交互式,无法下载webpack
这个问题出现的原因:

修改命令为
yarn install --production=false
2. 重新安装pm2后无法使用pm2
清除缓存即可。ps:会关闭所有pm2进程
sudo rm -rf ~/.pm2
3. 重新安装pm2原pm2启动的进程任然占用端口
// 查看端口占用
netstat -anp | grep 4003
输出:
tcp6 0 0 :::4003 :::* LISTEN 31984/PM2 v4.1.2: G
// 查看端口占用的进程
fuser -v -n tcp 4003
输出结果:
USER PID ACCESS COMMAND
4003/tcp: xxx 31984 F.... PM2 v4.1.2: God
// 杀掉进程
kill -s 9 [PID]
4. 使用本地私钥去获取git仓库
"ssh_options": "ForwardAgent=yes", // 采用本地的私钥
以前的做法是每台机器都生成钥匙对,并把公钥放入git仓库中。
不利于后续开发显而易见这样做换机器的时候都需要更新git仓库。
安全性差,每台机器中都有读写git的权限,万一被攻破了....