umi多环境配置:开发、测试、生产环境无缝切换

umi多环境配置:开发、测试、生产环境无缝切换

【免费下载链接】umi A framework in react community ✨ 【免费下载链接】umi 项目地址: https://gitcode.com/GitHub_Trending/um/umi

前言:为什么需要多环境配置?

在现代前端开发中,项目通常需要在多个环境中运行:开发环境(development)、测试环境(testing)、预发布环境(staging)和生产环境(production)。每个环境都有不同的配置需求:

  • 开发环境:需要热重载、详细的错误信息、调试工具
  • 测试环境:需要模拟数据、测试专用的API地址
  • 生产环境:需要代码压缩、性能优化、安全的配置

umi框架提供了强大的多环境配置机制,让你能够轻松管理不同环境的配置差异。

umi环境配置的核心机制

1. 环境变量识别

umi基于NODE_ENVUMI_ENV两个环境变量来识别当前运行环境:

// 环境判断逻辑
const isDev = process.env.NODE_ENV === 'development';
const isProd = process.env.NODE_ENV === 'production';
const env = process.env.UMI_ENV || ''; // 自定义环境标识

2. 配置文件优先级

umi支持多种配置文件格式,按以下优先级加载:

mermaid

实战:配置多环境项目

基础配置文件结构

首先创建基础的配置文件结构:

项目根目录/
├── 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的多环境配置,让你的应用在不同阶段都能发挥最佳性能,提升开发和部署效率。

【免费下载链接】umi A framework in react community ✨ 【免费下载链接】umi 项目地址: https://gitcode.com/GitHub_Trending/um/umi

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值