# 环境配置快速参考 ## 🚀 快速开始 ### 1. 创建开发环境配置 ```bash cd backend # 创建开发环境配置文件 cat > .env.development << 'EOF' NODE_ENV=development DATABASE_URL="mysql://root:password@localhost:3306/competition_management_dev?schema=public" JWT_SECRET="dev-secret-key" PORT=3001 EOF ``` ### 2. 创建生产环境配置 ```bash # 创建生产环境配置文件(不要提交到 Git) cat > .env.production << 'EOF' NODE_ENV=production DATABASE_URL="mysql://prod_user:strong_password@prod-host:3306/competition_management?schema=public&sslmode=require" JWT_SECRET="$(openssl rand -hex 32)" PORT=3001 EOF ``` ### 3. 创建数据库 ```sql -- 开发环境数据库 CREATE DATABASE competition_management_dev CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; -- 生产环境数据库 CREATE DATABASE competition_management CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ``` ### 4. 初始化数据库 ```bash # 开发环境 pnpm prisma:generate pnpm prisma:migrate # 生产环境(部署时) NODE_ENV=production pnpm prisma:migrate:deploy ``` ## 📋 环境区分总结 | 项目 | 开发环境 | 生产环境 | |------|---------|---------| | **配置文件** | `.env.development` | `.env.production` | | **数据库名** | `competition_management_dev` | `competition_management` | | **启动命令** | `pnpm start:dev` | `pnpm start:prod` | | **迁移命令** | `pnpm prisma:migrate` | `pnpm prisma:migrate:deploy` | | **Prisma Studio** | `pnpm prisma:studio:dev` | `pnpm prisma:studio:prod` | | **日志级别** | `debug` | `error` | | **CORS** | `*` (所有来源) | 指定域名 | | **SSL** | 可选 | 必须启用 | ## 🔑 关键区别 ### 开发环境 - ✅ 使用本地数据库 - ✅ 简单的 JWT 密钥(便于开发) - ✅ 详细的日志输出 - ✅ 允许所有 CORS 来源 - ✅ 热重载支持 ### 生产环境 - ✅ 独立的数据库服务器 - ✅ 强随机 JWT 密钥 - ✅ 最小化日志输出 - ✅ 限制 CORS 来源 - ✅ 启用 SSL/TLS - ✅ 连接池优化 ## 📝 配置文件示例 ### `.env.development` ```env NODE_ENV=development DATABASE_URL="mysql://root:password@localhost:3306/competition_management_dev?schema=public" JWT_SECRET="dev-secret-key" PORT=3001 LOG_LEVEL=debug CORS_ORIGIN=* ``` ### `.env.production` ```env NODE_ENV=production DATABASE_URL="mysql://prod_user:strong_password@prod-host:3306/competition_management?schema=public&sslmode=require" JWT_SECRET="your-production-secret-key-must-be-strong-and-random" PORT=3001 LOG_LEVEL=error CORS_ORIGIN=https://yourdomain.com SSL_ENABLED=true DB_POOL_MIN=2 DB_POOL_MAX=10 ``` ## ⚠️ 注意事项 1. **不要提交 `.env` 文件到 Git** 2. **生产环境必须使用强密码和 JWT_SECRET** 3. **生产环境建议启用 SSL 连接** 4. **定期备份生产数据库** 5. **使用不同的数据库名称区分环境** ## 🔍 验证配置 ```bash # 检查当前环境 echo $NODE_ENV # 验证数据库连接(开发环境) NODE_ENV=development pnpm prisma:studio # 验证数据库连接(生产环境) NODE_ENV=production pnpm prisma:studio:prod ``` 更多详细信息请查看 [ENVIRONMENT_CONFIG.md](./ENVIRONMENT_CONFIG.md)