main.py 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. # 主应用入口,整合多个 FastAPI 应用
  2. import uvicorn
  3. from fastapi import FastAPI
  4. from contextlib import asynccontextmanager
  5. # 导入所有子应用
  6. from src.api.search_infinity import app as search_app
  7. from src.api.tag_manage import app as tag_app
  8. from src.api.sdk.dataset_manage import app as dataset_app
  9. # 定义主应用的生命周期管理
  10. @asynccontextmanager
  11. async def main_lifespan(app: FastAPI):
  12. """主应用生命周期管理"""
  13. from src.utils.infinity import get_client, close_client
  14. # 1. 初始化Infinity全局客户端(在服务启动时)
  15. get_client(database="book_image_db")
  16. print("✅ Infinity客户端已初始化")
  17. # 2. 初始化MySQL全局客户端
  18. from src.utils.mysql import init_global_mysql_client, close_global_mysql_client
  19. init_global_mysql_client()
  20. print("✅ MySQL客户端已初始化")
  21. # 3. 初始化MinIO全局客户端并校验存储桶
  22. from src.utils.file.minio.minio_util import init_minio_client, close_minio_client
  23. init_minio_client(check_bucket=True)
  24. print("✅ MinIO客户端已初始化并校验存储桶")
  25. # 4. 启动Chunk更新定时任务
  26. from src.job.chunk_update_job import start_scheduler, shutdown_scheduler
  27. start_scheduler()
  28. print("✅ Chunk update scheduler started")
  29. yield
  30. # 1. 关闭Chunk更新定时任务
  31. shutdown_scheduler()
  32. print("✅ Chunk update scheduler shutdown")
  33. # 2. 关闭MinIO全局客户端
  34. close_minio_client()
  35. print("✅ MinIO客户端已关闭")
  36. # 3. 关闭MySQL全局客户端
  37. close_global_mysql_client()
  38. print("✅ MySQL客户端已关闭")
  39. # 4. 关闭Infinity全局客户端(在服务关闭时)
  40. close_client()
  41. print("✅ Infinity客户端已关闭")
  42. # 创建主应用
  43. main_app = FastAPI(
  44. title="Infinity API Gateway",
  45. description="整合多个 FastAPI 应用的 API 网关",
  46. version="1.0.0",
  47. lifespan=main_lifespan
  48. )
  49. # 挂载子应用
  50. # 1. 搜索 API - 访问路径: /search/*
  51. main_app.mount("/search", search_app, name="search_api")
  52. # 2. 标签管理 API - 访问路径: /tag/*
  53. main_app.mount("/tag", tag_app, name="tag_api")
  54. # 3. 数据集管理 API - 访问路径: /dataset/*
  55. main_app.mount("/dataset", dataset_app, name="dataset_api")
  56. # 主应用根路径
  57. @main_app.get("/")
  58. async def root():
  59. """API 网关根路径"""
  60. return {
  61. "message": "Welcome to GRAPH_RAG API Gateway",
  62. "available_apps": {
  63. "search_api": "访问路径: /search, 文档: /search/docs",
  64. "hybrid_http_api": "访问路径: /hybrid, 文档: /hybrid/docs",
  65. "tag_api": "访问路径: /tag, 文档: /tag/docs",
  66. "dataset_api": "访问路径: /dataset, 文档: /dataset/docs"
  67. }
  68. }
  69. # 健康检查端点
  70. @main_app.get("/health")
  71. async def health_check():
  72. """主应用健康检查"""
  73. return {"status": "healthy", "service": "Infinity API Gateway"}
  74. if __name__ == "__main__":
  75. print("=== 启动 GRAPH_RAG API Gateway ===")
  76. """启动主应用"""
  77. uvicorn.run(
  78. "main:main_app", # 应用路径: 模块名:应用实例名
  79. host="0.0.0.0", # 允许所有IP访问
  80. port=18001, # 服务端口
  81. reload=False, # 开发模式下自动重载
  82. workers=1, # 生产环境可根据需要增加
  83. log_level="info" # 日志级别
  84. )