该项目是基于
node
实现,对简单前端工程实现自动化部署至远端服务器指定目录。
更新:
🎉现已支持添加多个配置信息,自动化部署时支持选择配置信息运行
🎉现已支修改服务器连接端口,支持ssh私钥及解密密码连接(ps:不使用此方法时,请注释privateKey)
🎉现已更新模块引用逻辑,远端备份时间格式改为 yyyy-MM-dd_HH:mm:ss
优点:
- 轻量、便捷
- 可调节 本地压缩、远端备份
持续更新中,欢迎提交 issues
😘
Tip: 请确保已安装node、npm
npm install # 安装依赖
npm run deploy # 本地运行
1. 待部署工程本地完成打包构建
2. 确定远端部署目录及发布文件夹
3. 修改配置
4. 运行自动化部署
5. 查看远端效果
6. 再次部署 原目录已备份(开启远端备份生效)
/*
config.js
说明:
请确保解压后的文件目录为dist
ssh: 连接服务器用户信息
targetDir: 需要压缩的文件目录(启用本地压缩后生效)
targetFile: 指定上传文件名称(config.js同级目录)
openCompress: 关闭后,将跳过本地文件压缩,直接上传同级目录下指定文件
openBackUp: 开启后,若远端存在相同目录,则会修改原始目录名称,不会直接覆盖
deployDir: 指定远端部署地址
releaseDir: 指定远端部署地址下的发布目录名称
更新:
🎉现已支持添加多个配置信息,自动化部署时支持选择配置信息运行
🎉现已支修改服务器连接端口,支持ssh私钥及解密密码连接(ps:不使用此方法时,请注释privateKey)
🎉现已更新模块引用逻辑,远端备份时间格式改为 `yyyy-MM-dd_HH:mm:ss`
*/
const config = [
{
name: '项目A-dev',
ssh: {
host: '192.168.0.110',
port: 22,
username: 'root',
password: 'root',
privateKey: 'E:/id_rsa', // ssh私钥(不使用此方法时请勿填写, 注释即可)
passphrase: '123456' // ssh私钥对应解密密码(不存在设为''即可)
},
targetDir: 'E:/private/my-vue-cli/dist', // 目标压缩目录(可使用相对地址)
targetFile: 'dist.zip', // 目标文件
openCompress: true, // 是否开启本地压缩
openBackUp: true, // 是否开启远端备份
deployDir: '/home/node_test' + '/', // 远端目录
releaseDir: 'web' // 发布目录
}
]