umi多环境配置:开发、测试、生产环境无缝切换
2026-02-04 05:17:07作者:董灵辛Dennis
前言:为什么需要多环境配置?
在现代前端开发中,项目通常需要在多个环境中运行:开发环境(development)、测试环境(testing)、预发布环境(staging)和生产环境(production)。每个环境都有不同的配置需求:
- 开发环境:需要热重载、详细的错误信息、调试工具
- 测试环境:需要模拟数据、测试专用的API地址
- 生产环境:需要代码压缩、性能优化、安全的配置
umi框架提供了强大的多环境配置机制,让你能够轻松管理不同环境的配置差异。
umi环境配置的核心机制
1. 环境变量识别
umi基于NODE_ENV和UMI_ENV两个环境变量来识别当前运行环境:
// 环境判断逻辑
const isDev = process.env.NODE_ENV === 'development';
const isProd = process.env.NODE_ENV === 'production';
const env = process.env.UMI_ENV || ''; // 自定义环境标识
2. 配置文件优先级
umi支持多种配置文件格式,按以下优先级加载:
graph TD
A[.umirc.ts] --> B[config/config.ts]
B --> C[.umirc.${UMI_ENV}.ts]
C --> D[config/config.${UMI_ENV}.ts]
D --> E[环境变量覆盖]
实战:配置多环境项目
基础配置文件结构
首先创建基础的配置文件结构:
项目根目录/
├── config/
│ ├── config.ts # 基础配置
│ ├── config.dev.ts # 开发环境配置
│ ├── config.test.ts # 测试环境配置
│ └── config.prod.ts # 生产环境配置
├── .env # 全局环境变量
├── .env.development # 开发环境变量
├── .env.testing # 测试环境变量
└── .env.production # 生产环境变量
基础配置文件示例
config/config.ts - 基础配置
import { defineConfig } from 'umi';
export default defineConfig({
// 公共配置
publicPath: '/',
history: { type: 'browser' },
routes: [
{ path: '/', component: 'index' },
{ path: '/users', component: 'users' },
],
npmClient: 'pnpm',
});
config/config.dev.ts - 开发环境配置
import { defineConfig } from 'umi';
export default defineConfig({
// 开发环境特有配置
define: {
'process.env.API_BASE': 'http://localhost:8000/api',
'process.env.ENV': 'development',
},
devtool: 'cheap-module-source-map',
mock: {
include: ['src/mock/**/*.ts'],
},
fastRefresh: true,
});
config/config.test.ts - 测试环境配置
import { defineConfig } from 'umi';
export default defineConfig({
define: {
'process.env.API_BASE': 'https://test-api.example.com/api',
'process.env.ENV': 'testing',
},
// 测试环境关闭mock
mock: false,
// 测试环境特定的插件配置
extraBabelPlugins: [
['babel-plugin-istanbul', { extension: ['.ts', '.tsx'] }],
],
});
config/config.prod.ts - 生产环境配置
import { defineConfig } from 'umi';
export default defineConfig({
define: {
'process.env.API_BASE': 'https://api.example.com/api',
'process.env.ENV': 'production',
},
// 生产环境优化配置
jsMinifier: 'terser',
cssMinifier: 'cssnano',
manifest: {
fileName: 'asset-manifest.json',
},
// 生产环境关闭sourcemap
devtool: false,
// CDN配置
publicPath: 'https://cdn.example.com/',
});
环境变量文件配置
.env - 全局环境变量
# 项目基本信息
APP_NAME=My Umi App
APP_VERSION=1.0.0
# 通用API配置
API_TIMEOUT=10000
MAX_RETRY=3
.env.development - 开发环境
# 开发环境配置
NODE_ENV=development
UMI_ENV=dev
PORT=8000
HOST=localhost
# 开发环境API
API_BASE=http://localhost:8000/api
MOCK_ENABLED=true
DEBUG=true
.env.testing - 测试环境
# 测试环境配置
NODE_ENV=production
UMI_ENV=test
PORT=3000
# 测试环境API
API_BASE=https://test-api.example.com/api
MOCK_ENABLED=false
DEBUG=false
.env.production - 生产环境
# 生产环境配置
NODE_ENV=production
UMI_ENV=prod
PORT=80
# 生产环境API
API_BASE=https://api.example.com/api
MOCK_ENABLED=false
DEBUG=false
环境特定的运行时配置
动态配置加载
在代码中可以根据环境动态加载配置:
// src/utils/env.ts
export const getEnvConfig = () => {
const env = process.env.UMI_ENV || 'dev';
const configs = {
dev: {
apiBase: 'http://localhost:8000/api',
logLevel: 'debug',
features: ['mock', 'devTools'],
},
test: {
apiBase: 'https://test-api.example.com/api',
logLevel: 'info',
features: ['analytics'],
},
prod: {
apiBase: 'https://api.example.com/api',
logLevel: 'warn',
features: ['analytics', 'monitoring'],
},
};
return configs[env] || configs.dev;
};
环境感知的组件
创建能够感知环境的React组件:
// src/components/EnvironmentAwareComponent.tsx
import React from 'react';
import { getEnvConfig } from '@/utils/env';
const EnvironmentAwareComponent: React.FC = () => {
const envConfig = getEnvConfig();
const isDevelopment = process.env.NODE_ENV === 'development';
return (
<div className="env-banner">
<h3>当前环境: {process.env.UMI_ENV || 'development'}</h3>
<p>API地址: {envConfig.apiBase}</p>
{isDevelopment && (
<div className="dev-features">
<button onClick={() => console.log('开发工具')}>开发工具</button>
<button onClick={() => alert('Mock数据')}>Mock功能</button>
</div>
)}
</div>
);
};
export default EnvironmentAwareComponent;
构建和部署脚本
package.json脚本配置
{
"scripts": {
"dev": "umi dev",
"build:dev": "UMI_ENV=dev umi build",
"build:test": "UMI_ENV=test umi build",
"build:prod": "UMI_ENV=prod umi build",
"start:dev": "UMI_ENV=dev umi dev",
"start:test": "UMI_ENV=test PORT=3000 umi dev",
"analyze": "ANALYZE=1 umi build"
}
}
自动化部署脚本
#!/bin/bash
# deploy.sh
ENV=${1:-prod}
echo "开始部署到 $ENV 环境"
# 根据环境选择配置
case $ENV in
dev)
npm run build:dev
DEPLOY_PATH="/var/www/dev"
;;
test)
npm run build:test
DEPLOY_PATH="/var/www/test"
;;
prod)
npm run build:prod
DEPLOY_PATH="/var/www/prod"
;;
*)
echo "未知环境: $ENV"
exit 1
;;
esac
# 部署逻辑
rsync -avz dist/ user@server:$DEPLOY_PATH/
echo "部署完成到 $DEPLOY_PATH"
环境配置最佳实践
1. 安全敏感信息处理
// 使用环境变量管理敏感信息
export default defineConfig({
define: {
'process.env.API_KEY': process.env.API_KEY || '',
'process.env.DATABASE_URL': process.env.DATABASE_URL || '',
},
});
2. 环境特定的插件配置
// 根据环境启用不同的插件
const plugins = [
// 基础插件
'@umijs/plugins/dist/initial-state',
'@umijs/plugins/dist/model',
];
if (process.env.UMI_ENV === 'dev') {
plugins.push('@umijs/plugins/dist/dva'); // 仅开发环境使用dva
}
export default defineConfig({
plugins,
});
3. 环境检测工具函数
// src/utils/environment.ts
export const Environment = {
isDev: () => process.env.NODE_ENV === 'development',
isTest: () => process.env.UMI_ENV === 'test',
isProd: () => process.env.NODE_ENV === 'production' && process.env.UMI_ENV === 'prod',
getCurrent: () => {
if (process.env.UMI_ENV) return process.env.UMI_ENV;
return process.env.NODE_ENV === 'development' ? 'dev' : 'prod';
},
// 功能开关
features: {
mock: () => Environment.isDev() || process.env.MOCK_ENABLED === 'true',
analytics: () => !Environment.isDev(),
debug: () => Environment.isDev() || process.env.DEBUG === 'true',
},
};
常见问题排查
环境变量未生效?
检查启动命令是否正确设置环境变量:
# 正确的方式
UMI_ENV=test npm run build
# 错误的方式(环境变量不会传递)
npm run build UMI_ENV=test
配置合并问题?
umi的配置合并遵循特定规则,可以使用console.log调试:
export default defineConfig(async () => {
const config = {
// 你的配置
};
if (process.env.UMI_ENV === 'dev') {
console.log('开发环境配置加载');
}
return config;
});
总结
umi的多环境配置机制提供了灵活而强大的环境管理能力。通过合理使用环境变量、配置文件优先级和运行时检测,你可以实现:
- 🚀 无缝环境切换:通过简单的环境变量切换不同配置
- 🔒 安全隔离:敏感信息通过环境变量管理,不进入代码仓库
- ⚡ 性能优化:不同环境使用不同的优化策略
- 🐛 调试友好:开发环境提供完整的调试支持
- 📊 监控就绪:生产环境集成监控和分析工具
掌握umi的多环境配置,让你的应用在不同阶段都能发挥最佳性能,提升开发和部署效率。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
Ascend Extension for PyTorch
Python
618
795
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
433
395
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.18 K
152
deepin linux kernel
C
29
16
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
145
237
暂无简介
Dart
983
252
昇腾LLM分布式训练框架
Python
166
198
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.68 K
989