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

相关推荐
2301_796512523 分钟前
【精通篇】打造React Native鸿蒙跨平台开发高级复合组件库开发系列:Lazyload 懒加载(懒加载的图片)
前端·javascript·react native·react.js·ecmascript·harmonyos
敲敲了个代码8 分钟前
从N倍人力到1次修改:Vite Plugin Modular 如何拯救多产品前端维护困境
前端·javascript·面试·职场和发展·typescript·vite
Yff_world16 分钟前
网络安全与 Web 基础笔记
前端·笔记·web安全
Sapphire~16 分钟前
Vue3-19 hooks 前端数据和方法的封装
前端·vue3
浩宇软件开发25 分钟前
基于OpenHarmony鸿蒙开发医院预约挂号系统(前端后端分离)
前端·华为·harmonyos
嘿是我呀32 分钟前
【用npm安装node时报错“npm 无法加载文件”】
前端·npm·node.js
干前端33 分钟前
Vue3 组件库工程化实战:BEM 命名规范与 useNamespace 深度解析
前端·css
弓弧名家_玄真君35 分钟前
在ubuntu中安装redis
前端·bootstrap·mybatis
RFCEO36 分钟前
学习前端编程:DOM 树、CSSOM 树、渲染树详解
前端·学习·渲染树·dom 树·cssom 树·浏览器的渲染流程·回流/重绘
笨蛋不要掉眼泪39 分钟前
Redis主从复制:原理、配置与实战演示
前端·redis·bootstrap·html