vue项目打包后,自动部署到服务器上面

背景

项目有多个开发环境,作者希望项目打包后可以自动上传到服务器,省略掉本地打包-连接服务器-上传文件等一系列操作,提高工作效率

解决方式

使用scp2

  1. 安装scp2 npm install scp2 --save-dev

  2. 在根目录下生成dev.js脚本

javascript 复制代码
const client = require('scp2');
const ora = require('ora');
const chalk = require('chalk');
const spinner = ora(chalk.green('正在发布到测试服务器...'));

spinner.start();
client.scp('./dist/', {
  "host": 'xxx.xxx.xx.xx',
  "port": 'xxx',
  "username": 'xxxx',
  "privateKey": require('fs').readFileSync('/path/to/your/private/key'),
  "path": '/www/websites/www/pt/dist/11'}, err =>{
  spinner.stop();
  if (!err) {
    console.log(chalk.green("测试服务器部署完毕。"))
  } else {
    console.log("err", err)
}})

使用SSH密钥认证(更安全)

  1. 在.gitignore中忽略node脚本( 安全性)

  2. 在package.json中添加脚本命令

rust 复制代码
'dev:server':'npm run build &&  node dev.js

dev:server 将打包和部署放在同一个指令执行

相关推荐
JarvanMo1 分钟前
情迷服务器驱动 UI:我在 Flutter 开发中的爱与哀愁
前端
tzy2334 分钟前
分享一个 HTTP(S) 代理&抓包工具,拦截和Mock Web客户端请求和服务端响应
前端·网络协议·http
代码小学僧9 分钟前
普通前端仔的 2025 : 年终总结与 AI 对我的影响
前端·程序员·ai编程
Mike_jia16 分钟前
TCP 粘包/拆包问题
前端
沐墨染23 分钟前
敏感词智能检索前端组件设计:树形组织过滤与多维数据分析
前端·javascript·vue.js·ui·数据挖掘·数据分析
Kagol25 分钟前
🎉TinyPro v1.4.0 正式发布:支持 Spring Boot、移动端适配、新增卡片列表和高级表单页面
前端·typescript·开源
李少兄26 分钟前
B/S 架构:现代 Web 应用的核心架构模式
前端·架构·b/s
鹏程十八少39 分钟前
破解Android悬浮窗遮挡无障碍服务难题:我在可见即可说上踩过的坑
android·前端·面试
Kapaseker43 分钟前
前端已死...了吗
android·前端·javascript
m0_471199631 小时前
【自动化】前端开发,如何将 Jenkins 与 Gitee 结合实现自动化的持续集成(构建)和持续部署(发布)
前端·gitee·自动化·jenkins