pm2是一个node的守护进程管理器
学习的原因
最近在公司的旧项目改造中,把一个旧项目拆分成了3个项目,并用nginx配置成了一个项目。
在开发中,调试环境的发布比较繁琐,经常要到服务器拉取代码、重新打包项目、重启服务。
而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": "StrictHostKeyChecking=no",
"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的代码
生成公钥并添加到github中的settings中
pm2踩坑(19.11.14日更新)
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
这个问题出现的原因:
pm2
修改命令为
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]