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的多环境配置,让你的应用在不同阶段都能发挥最佳性能,提升开发和部署效率。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0193- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
awesome-zig一个关于 Zig 优秀库及资源的协作列表。Makefile00
热门内容推荐
最新内容推荐
pi-mono自定义工具开发实战指南:从入门到精通3个实时风控价值:Flink CDC+ClickHouse在金融反欺诈的实时监测指南Docling 实用指南:从核心功能到配置实践自动化票务处理系统在高并发抢票场景中的技术实现:从手动抢购痛点到智能化解决方案OpenCore Legacy Patcher显卡驱动适配指南:让老Mac焕发新生7个维度掌握Avalonia:跨平台UI框架从入门到架构师Warp框架安装部署解决方案:从环境诊断到容器化实战指南突破移动瓶颈:kkFileView的5层适配架构与全场景实战指南革新智能交互:xiaozhi-esp32如何实现百元级AI对话机器人如何打造专属AI服务器?本地部署大模型的全流程实战指南
项目优选
收起
deepin linux kernel
C
27
12
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
601
4.04 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
Ascend Extension for PyTorch
Python
441
531
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
112
170
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.46 K
824
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
922
770
暂无简介
Dart
846
204
React Native鸿蒙化仓库
JavaScript
321
375
openGauss kernel ~ openGauss is an open source relational database management system
C++
174
249