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 将打包和部署放在同一个指令执行

相关推荐
哆啦A梦158834 分钟前
axios 的二次封装
前端·vue.js·node.js
阿珊和她的猫42 分钟前
深入理解与手写发布订阅模式
开发语言·前端·javascript·vue.js·ecmascript·状态模式
yinuo1 小时前
一行 CSS 就能搞定!用 writing-mode 轻松实现文字竖排
前端
snow@li1 小时前
html5:拖放 / demo / 拖放事件(Drag Events)/ DataTransfer 对象方法
前端·html·拖放
浪裡遊3 小时前
Nivo图表库全面指南:配置与用法详解
前端·javascript·react.js·node.js·php
漂流瓶jz4 小时前
快速定位源码问题:SourceMap的生成/使用/文件格式与历史
前端·javascript·前端工程化
samroom4 小时前
iframe实战:跨域通信与安全隔离
前端·安全
fury_1234 小时前
vue3:数组的.includes方法怎么使用
前端·javascript·vue.js
weixin_405023374 小时前
包资源管理器NPM 使用
前端·npm·node.js
宁&沉沦4 小时前
Cursor 科技感的登录页面提示词
前端·javascript·vue.js