PM2 ecosystem 服务器自动化部署
一:准备工作
1.1 :将项目上传至代码管理库(github,gitlab,bitbucket,等)
1.2 :Windows 和 服务器 都安装SSH,Git 工具。
二:开始
2.1 本地生成ssh key连接服务器
//根据邮箱生成ssh key ssh-keygen -t rsa -C "..........@163.com" //仔细看注释 //1.如果生成过一次ssh key,就别一路回车了。中间有一步是需要确认覆盖ssh key的。
2.2 将本地id_rsa.pub里面的内容复制下来(路径是C:\Users\Administrator\.ssh),添加进服务器~/.ssh/authorized_keys文件中。
(服务器中authorized_keys文件)

2.3 在根据2.1步骤在服务器生成ssh key。此处就不过多写了。
2.4 在将服务器中生成的id_rsa.pub复制下来(路径是~/.ssh),添加进github ssh key。(这里以github为例)
位置在(右上角个人中心/Settings)进去

三:编码(生成pm2部署文件)
3.1 找一个位置生成ecosystem.config.js部署文件。

3.2 编译部署文件。
module.exports = {
apps: [{
// 应用程序名称
name: 'www',
// 应用程序目录,其他的路径配置如果是相对路径,则会相对此目录
cwd: '/www/wlink/current/wlink_service/bin/',
// 启动脚本
script: 'www',
// Options reference: https://pm2.io/doc/en/runtime/reference/ecosystem-file/
args: 'one two',
instances: 'max',
autorestart: true,
watch: false,
max_memory_restart: '1G',
env_production: {
NODE_ENV: 'production'
},
}],
// 部署部份
deploy: {
production: {
// 服务器用户名
user: 'root',
// 服务器 IP 地址
host: '127.0.0.1',
// git 分支
ref: 'origin/master',
// GIT 远程仓库地址
repo: 'git@github.com:dlw1398287387/Wlink_Table.git',
// 应用程序在服务器上的部署路径
path: '/www/wlink',
// 安装前在服务器执行的命令,可以是 “;” 分割的多个命名,也可以是本地的脚本路径
// 'pre-setup': 'apt-get install git',
// 安装后在服务器执行的命令,也可以是服务器上脚本的路径
'post-setup': 'sh /www/wlink/current/wlink_service/www.sh',
// 部署前在本地执行的命令,可以是 “;” 分割的多个命名
'pre-deploy-local': "echo 'hello word'",
// 部署后在服务器执行的命令
'post-deploy': 'cnpm install && pm2 reload ecosystem.config.js --env production',
env: {
NODE_ENV: "production"
}
}
}
};
*3.3 SSH 远程连接github (此处最重要)
//在服务器执行 ssh git@github.com

3.4 执行ecosystem.config.js部署文件
使用git工具进入到刚刚生成的部署文件目录。执行(此为部署,释义:将代码clone到服务器指定位置)
pm2 deploy ecosystem.config.js production setup

静静等待项目部署就OK。

3.5 执行ecosystem.config.js启动项目 (释义:pm2 start app.js)
pm2 deploy ecosystem.config.js production
结束!
部分内容来源网络,如有侵犯到您的权益请联系leeke98@foxmail.com进行下架处理

浙公网安备 33010602011771号