3.1 KiB
3.1 KiB
环境配置快速参考
🚀 快速开始
1. 创建开发环境配置
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. 创建生产环境配置
# 创建生产环境配置文件(不要提交到 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. 创建数据库
-- 开发环境数据库
CREATE DATABASE competition_management_dev
CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
-- 生产环境数据库
CREATE DATABASE competition_management
CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
4. 初始化数据库
# 开发环境
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
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
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
⚠️ 注意事项
- 不要提交
.env文件到 Git - 生产环境必须使用强密码和 JWT_SECRET
- 生产环境建议启用 SSL 连接
- 定期备份生产数据库
- 使用不同的数据库名称区分环境
🔍 验证配置
# 检查当前环境
echo $NODE_ENV
# 验证数据库连接(开发环境)
NODE_ENV=development pnpm prisma:studio
# 验证数据库连接(生产环境)
NODE_ENV=production pnpm prisma:studio:prod
更多详细信息请查看 ENVIRONMENT_CONFIG.md