自动找空闲端口再启动 mock-server」的脚本

一个完整的 自动分配 mock-server 和前端服务端口 的启动脚本 ✨,可以放在项目根目录,例如 start-dev.js


✅ 目录结构约定

项目结构示例:

lua 复制代码
project-root/
├── .env.local
├── start-dev.js ← 👈 新增
├── package.json
├── mock-server/
│   └── index.mjs
├── src/
│   └── muiUI/
│       └── apps/
│           └── cardUI/
│               └── rsbuild.config.ts

✅ 第一步:安装依赖

csharp 复制代码
pnpm add -D dotenv get-port concurrently

✅ 第二步:修改 .env.local 支持默认端口

ini 复制代码
# 可写默认值,但自动脚本可覆盖它
VITE_MOCK_PORT=3001
VITE_DEV_PORT=4200

✅ 第三步:start-dev.js 自动找端口并启动

ini 复制代码
// start-dev.js
import { exec } from 'child_process';
import * as dotenv from 'dotenv';
import getPort from 'get-port';
import path from 'path';
import fs from 'fs';

dotenv.config({ path: path.resolve(__dirname, '.env.local') });

const start = async () => {
  const defaultMockPort = parseInt(process.env.VITE_MOCK_PORT || '3001');
  const defaultDevPort = parseInt(process.env.VITE_DEV_PORT || '4200');

  const mockPort = await getPort({ port: defaultMockPort });
  const devPort = await getPort({ port: defaultDevPort });

  // 动态更新 .env.local 中的端口(可选)
  const envPath = path.resolve(__dirname, '.env.local');
  let envContent = fs.readFileSync(envPath, 'utf-8');

  envContent = envContent
    .replace(/VITE_MOCK_PORT=.*/, `VITE_MOCK_PORT=${mockPort}`)
    .replace(/VITE_DEV_PORT=.*/, `VITE_DEV_PORT=${devPort}`);

  fs.writeFileSync(envPath, envContent);
  console.log(`✅ 端口更新成功:mock=${mockPort}, dev=${devPort}`);

  // 启动 mock-server + 前端服务(cardUI)
  const command = `concurrently -n MOCK,DEV -c yellow,cyan "pnpm --filter mock-server dev" "pnpm --filter @muiUI/cardui dev"`;

  const child = exec(command, { cwd: __dirname });

  child.stdout?.pipe(process.stdout);
  child.stderr?.pipe(process.stderr);
};

start();

✅ 第四步:mock-server/index.mjs 中读取端口

ini 复制代码
// mock-server/index.mjs
import jsonServer from 'json-server';
import dotenv from 'dotenv';

dotenv.config({ path: '../../.env.local' }); // 根据实际位置调整

const port = process.env.VITE_MOCK_PORT || 3001;
const server = jsonServer.create();
const router = jsonServer.router('db.json');
const middlewares = jsonServer.defaults();

server.use(middlewares);
server.use(router);

server.listen(port, () => {
  console.log(`🚀 mock-server running on http://localhost:${port}`);
});

✅ 第五步:package.json 中添加启动命令

json 复制代码
// 根目录的 package.json
{
  "scripts": {
    "dev": "node start-dev.js"
  }
}

🧪 启动项目

复制代码
pnpm dev

它会:

  • 自动找两个没被占用的端口(mock / 前端)
  • 写入 .env.local
  • 并用 concurrently 启动 mock-server 和 cardUI 前端

相关推荐
军军君011 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
落霞的思绪4 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Highcharts.js6 小时前
使用Highcharts与React集成 官网文档使用说明
前端·react.js·前端框架·react·highcharts·官方文档
晚霞的不甘9 小时前
Flutter for OpenHarmony从基础到专业:深度解析新版番茄钟的倒计时优化
android·flutter·ui·正则表达式·前端框架·鸿蒙
晚霞的不甘11 小时前
Flutter for OpenHarmony专注与习惯的完美融合: 打造你的高效生活助手
前端·数据库·经验分享·flutter·前端框架·生活
总爱写点小BUG12 小时前
UniApp 图标方案终极排坑:告别 FontClass,拥抱真 SVG 组件化
前端框架·uni-app
总爱写点小BUG12 小时前
探索 vu-icons:一款轻量级、跨平台的 Vue3 & UniApp SVG 图标库
前端·前端框架·组件库
晚霞的不甘12 小时前
Flutter for OpenHarmony手势涂鸦画板开发详解
前端·学习·flutter·前端框架·交互
晚霞的不甘12 小时前
Flutter for OpenHarmony 实现动态天气与空气质量仪表盘:从 UI 到动画的完整解析
前端·flutter·ui·前端框架·交互
晚霞的不甘13 小时前
Flutter for OpenHarmony 实现 iOS 风格科学计算器:从 UI 到表达式求值的完整解析
前端·flutter·ui·ios·前端框架·交互