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的多环境配置,让你的应用在不同阶段都能发挥最佳性能,提升开发和部署效率。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
525
3.72 K
Ascend Extension for PyTorch
Python
332
395
暂无简介
Dart
766
189
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
878
586
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
336
165
React Native鸿蒙化仓库
JavaScript
302
352
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.33 K
748
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
985
246