feat: 初始化考培练系统项目

- 从服务器拉取完整代码
- 按框架规范整理项目结构
- 配置 Drone CI 测试环境部署
- 包含后端(FastAPI)、前端(Vue3)、管理端

技术栈: Vue3 + TypeScript + FastAPI + MySQL
This commit is contained in:
111
2026-01-24 19:33:28 +08:00
commit 998211c483
1197 changed files with 228429 additions and 0 deletions

91
backend/start_mysql.py Normal file
View File

@@ -0,0 +1,91 @@
#!/usr/bin/env python3
"""
MySQL环境启动脚本
使用MySQL数据库进行开发测试
"""
import os
import sys
import asyncio
from pathlib import Path
# 设置环境变量 - 使用公网MySQL数据库
# 密码需要URL编码: Kaopeilian2025!@# -> Kaopeilian2025%21%40%23
os.environ["DATABASE_URL"] = "mysql+aiomysql://root:Kaopeilian2025%21%40%23@120.79.247.16:3306/kaopeilian"
os.environ["SECRET_KEY"] = "dev-secret-key-for-testing-only-not-for-production"
os.environ["DEBUG"] = "true"
os.environ["LOG_LEVEL"] = "INFO"
os.environ["LOG_FORMAT"] = "console"
os.environ["REDIS_URL"] = "redis://localhost:6379/0"
# 添加项目根目录到Python路径
project_root = Path(__file__).parent
sys.path.insert(0, str(project_root))
async def create_database():
"""创建数据库(如果不存在)"""
try:
import aiomysql
# 连接到公网MySQL服务器不指定数据库
conn = await aiomysql.connect(
host='120.79.247.16',
port=3306,
user='root',
password='Kaopeilian2025!@#'
)
cursor = await conn.cursor()
# 创建数据库
await cursor.execute("CREATE DATABASE IF NOT EXISTS kaopeilian CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci")
print("✅ 数据库 'kaopeilian' 创建成功")
await cursor.close()
conn.close()
except Exception as e:
print(f"⚠️ 数据库创建警告: {e}")
print("请确保MySQL服务正在运行并且用户root的密码是'root'")
async def create_tables():
"""创建数据库表"""
try:
from app.config.database import engine
from app.models.base import Base
async with engine.begin() as conn:
await conn.run_sync(Base.metadata.create_all)
print("✅ 数据库表创建成功")
except Exception as e:
print(f"❌ 数据库表创建失败: {e}")
print("请检查MySQL连接配置")
async def main():
"""主函数"""
print("🚀 启动考培练系统后端服务 (MySQL版本)...")
# 创建数据库
await create_database()
# 创建数据库表
await create_tables()
# 启动服务
import uvicorn
from app.main import app
print("📚 API文档地址: http://localhost:8000/api/v1/docs")
print("🔍 健康检查: http://localhost:8000/health")
print("🗄️ 数据库: MySQL (kaopeilian)")
print("⏹️ 按 Ctrl+C 停止服务")
uvicorn.run(
app,
host="0.0.0.0",
port=8000,
reload=True,
log_level="info"
)
if __name__ == "__main__":
asyncio.run(main())