解决小项目中的频繁部署-适用于没有Jenkins或者没有配置流水线的前端部署

背景

对于一些演示项目,或者公司内部没有流水线的情况下,我们前端项目部署问题,需要频繁额ssh unzip等等操作极其麻烦,或者使用xftp等传出工具,也需要频繁打开客户端 或者频繁的上传拖动打包文件。

基于此,我们前端项目有没有直接再没有流水线的情况下,直接直接执行 npm run build:deploy或者 npm run build 再次 npm run deploy就直接更新服务器资源了,

以上适用用nginx部署的前端服务,每次部署完文件 不需要reload 或者 重启镜像的情况

实现

安装依赖

js 复制代码
npm i scp2 -S

package.json 中增加命令

js 复制代码
 "deploy": "node deploy.js",
  "build:deploy": "npm run build && npm run deploy",

根目录增加

deploy.js文件,你需要修改的就是 服务器的信息 以及部署的目录

js 复制代码
import scpClient from 'scp2'
import path from 'path'
import fs from 'fs'

// 服务器配置
const serverConfig = {
  host: '172.11.111.222',    // 服务器IP
  port: 111,                 // 端口
  username: 'root',          // 用户名
  password: '******',  // 密码
  path: '/aaa/bb'          // 部署路径
}

const localDistPath = path.join(process.cwd(), './dist')

if (!fs.existsSync(localDistPath)) {
  console.error('错误:dist目录不存在,请先执行构建命令')
  process.exit(1)
}

console.log(`开始上传dist文件夹到 ${serverConfig.host}:${serverConfig.path}...`)

scpClient.scp(
  localDistPath,
  serverConfig,
  (err) => {
    if (err) {
      console.error('上传失败:', err)
      process.exit(1)
    } else {
      console.log('✅ dist文件夹已成功上传到服务器!')
      process.exit(0)
    }
  }
)

更安全的SFTP

js 复制代码
import Client from 'ssh2-sftp-client'
import path from 'path'
import fs from 'fs'

// 服务器配置
const serverConfig = {
  host: '172.11.111.222',    // 服务器IP
  port: 111,                 // 端口
  username: 'root',          // 用户名
  password: '******',  // 密码
  path: '/aaa/bb'          // 部署路径
}

const localDistPath = path.join(process.cwd(), './dist')

if (!fs.existsSync(localDistPath)) {
  console.error('错误:dist目录不存在,请先执行构建命令')
  process.exit(1)
}

console.log(`开始上传 dist 文件夹到 ${serverConfig.host}:${serverConfig.path}...`)

const sftp = new Client()

sftp.connect({
  host: serverConfig.host,
  port: serverConfig.port,
  username: serverConfig.username,
  password: serverConfig.password
})
  .then(() => {
    return sftp.uploadDir(localDistPath, serverConfig.path)
  })
  .then(() => {
    console.log('✅ dist文件夹已成功上传到服务器!')
    process.exit(0)
  })
  .catch((err) => {
    console.error('上传失败:', err)
    process.exit(1)
  })
  .finally(() => {
    sftp.end() // 关闭SFTP连接
  })

安全优化

服务器信息不应该写死,且不应该传递到 仓库中,可以自己创建 环境变量写入,并忽略提交

根目录创建 .env.deploy环境配置文件

js 复制代码
# .env.deploy
VITE_SFTP_HOST=172.11.111.222
VITE_SFTP_PORT=111
VITE_SFTP_USERNAME=root
VITE_SFTP_PASSWORD=******
VITE_SFTP_REMOTE_PATH=/aaa/bb

package.json做更改

js 复制代码
 "build:deploy": "vite build && node --env-file=.env.deploy deploy.js",
    "deploy": "node --env-file=.env.deploy deploy.js",

.gitignore修改

增加 .env.deploy 忽略提交

deploy.js更改

js 复制代码
import Client from 'ssh2-sftp-client'
import path from 'path'
import fs from 'fs'

// 从环境变量获取配置
const serverConfig = {
  host: process.env.VITE_SFTP_HOST,
  port: parseInt(process.env.VITE_SFTP_PORT || '22'),
  username: process.env.VITE_SFTP_USERNAME,
  password: process.env.VITE_SFTP_PASSWORD,
  path: process.env.VITE_SFTP_REMOTE_PATH
}


const localDistPath = path.join(process.cwd(), './dist')

if (!fs.existsSync(localDistPath)) {
  console.error('错误:dist目录不存在,请先执行构建命令')
  process.exit(1)
}

console.log(`开始上传 dist 文件夹到 ${serverConfig.host}:${serverConfig.path}...`)

const sftp = new Client()

sftp.connect({
  host: serverConfig.host,
  port: serverConfig.port,
  username: serverConfig.username,
  password: serverConfig.password
})
  .then(() => {
    return sftp.uploadDir(localDistPath, serverConfig.path)
  })
  .then(() => {
    console.log('✅ dist文件夹已成功上传到服务器!')
    process.exit(0)
  })
  .catch((err) => {
    console.error('上传失败:', err)
    process.exit(1)
  })
  .finally(() => {
    sftp.end() // 关闭SFTP连接
  })

执行

1:完整流程:

  1. 先运行 vite build 构建项目
  2. 如果构建成功,自动运行部署脚本
  3. 部署脚本会读取 .env.deploy 中的敏感信息(服务器账号等)
  4. dist 目录上传到服务器

2:也可在直接一键式部署

js 复制代码
npm run build:deploy
相关推荐
LaoZhangAI2 分钟前
FLUX.1 API图像尺寸设置全指南:优化生成效果与成本
前端·后端
哑巴语天雨11 分钟前
Cesium初探-CallbackProperty
开发语言·前端·javascript·3d
JosieBook29 分钟前
【前端】Vue 3 页面开发标准框架解析:基于实战案例的完整指南
前端·javascript·vue.js
liwei_fang31 分钟前
node.js 调度 --- 事件循环
前端
薄荷椰果抹茶33 分钟前
前端技术之---应用国际化(vue-i18n)
前端·javascript·vue.js
鹿啦啦SHARE33 分钟前
volta了解和使用
前端
小高0071 小时前
掌握 requestFullscreen:网页全屏功能的实用指南与技巧
前端
前端付豪1 小时前
22、前端工程化深度实践:构建、发布、CI/CD 流程重构指南
前端·javascript·架构
我是若尘1 小时前
从“全大图”到“响应式加载”:企业级前端图片优化全攻略(含Vue/React自动化方案)
前端