architecture.mdc 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. ---
  2. description: 项目架构描述,技术栈,功能项描述。
  3. alwaysApply: true
  4. ---
  5. # 项目架构描述
  6. ## 技术栈
  7. - 语言:Java 21
  8. - 框架:Spring Boot 3.5.12.RELEASE
  9. - 数据库:PostgreSQL 15
  10. - 构建工具:Maven 3.8.9
  11. - 认证方式:JWT 认证
  12. - 生产环境:linux
  13. - 文件存储:FastDFS、MinIO
  14. - 缓存服务:Caffeine 本地缓存、Redis
  15. ## 功能模块
  16. 主要包括:
  17. - 向Mcp客户端或Agent提供Tool工具列表
  18. - 向Mcp客户端或Agent提供Tool工具的能力
  19. ## 项目层次约束
  20. **该项目层次清晰,划分严格,指定功能模块必须严格按如下层次进行归类,不可随意归类或放置。**
  21. - `src/main/java/com/shkpr/service/mcpcenterservice/`
  22. - `handler/` — 实际业务逻辑处理类
  23. - `mcptool/` — 定义所有的tool类
  24. - `commtools/` — 通用工具类
  25. - `components/` — 组件(如自定义验证器)封装类
  26. - `configuration/` — 各种配置类
  27. - `constants/` — 全局常量定义
  28. - `filters/` — 全局过滤封装类
  29. - `dbdao/mapper/` — 主业务数据库访问的 Mapper 定义类
  30. - `dbdao/services/` — 数据库访问的 DAO 服务实现
  31. - `dbdao/services/intef/` — DAO 服务接口定义
  32. - `dbdao/providers/` — Mapper 动态 SQL 提供者
  33. - `dbdao/pgtype/` — PostgreSQL 自定义类型处理
  34. - `dbdao/tables/` — 表结构/字段常量说明
  35. - `dto/` — 数据库或业务层模型对象
  36. - `exception/` — 全局异常处理
  37. - `factorys/` — 工厂类
  38. - `globalcache/` — 全局缓存控制类
  39. - `globalmgr/` — 全局管理器
  40. - `jsonbean/` — 请求参数定义类
  41. - `queues/` — 自定义队列管理类
  42. - `services/` — 本项目调用第三方服务(或其他服务)的封装类
  43. - `subtask/` — 自定义子任务管理类
  44. - `src/main/resources/`
  45. - `application.properties` — 主配置
  46. - `logback.xml` — 日志配置
  47. - `sql.properties` — 数据库参数配置(常与 `global.sql.config.path` 配合)
  48. - `pom.xml` — 构建配置
  49. - `libs/` — 第三方本地 JAR(含 gbase 等)
  50. - `config/` — 外部业务参数配置
  51. ## 关键设计模式
  52. **该项目需要严格遵守该设计模式。**
  53. 1. 在`mcptool`目录下定义所有向外提供的tool方法,其方法中实际的业务处理逻辑需放在`handler`目录下进行封装定义并实现。
  54. 2. 业务处理层(如 `PatrolPlanHelper`)必须通过 **`DBMgrProxy`** 调用数据库的 DAO 服务层。
  55. 3. **`DBMgrProxy`** 为数据库访问单例代理,管理多个数据源连接。
  56. 4. **`LogPrintMgr`** 为统一日志管理类。