3.0 KiB
3.0 KiB
架构说明
系统采用前后端分离加双数据库架构。Docker Compose 会启动 PostgreSQL、FalkorDB 和 FastAPI API 服务;React 管理后台在镜像构建时被打包为静态文件,由 FastAPI 挂载到 /admin。
容器拓扑
flowchart TB
subgraph compose["Docker Compose"]
API["api\nFastAPI + 静态后台"]
PG["postgres\nPostgreSQL 16"]
Seed["falkordb-seed\n复制 dump.rdb"]
FK["falkordb\nFalkorDB"]
end
Browser["浏览器"] --> API
API --> PG
API --> FK
Seed --> FK
服务职责
| 服务 | 职责 |
|---|---|
api |
提供 /v1/admin/* API,挂载 /admin 前端页面,连接 PostgreSQL 与 FalkorDB |
postgres |
保存后台业务数据、用户权限、项目、候选实体、审核记录和任务 |
falkordb-seed |
首次启动时把仓库内的 snapshots/falkordb/dump.rdb 写入数据卷 |
falkordb |
保存图数据库,支持 Cypher/Redis 协议访问和 FalkorDB Browser |
后端模块
| 路径 | 说明 |
|---|---|
app/main.py |
FastAPI 入口、CORS、路由挂载和前端静态资源挂载 |
app/config.py |
环境变量配置 |
app/db.py |
PostgreSQL 连接池 |
app/api/ |
管理后台 API 路由 |
app/agents/ |
采集、抽取、对齐、审计和外部站点 Agent |
app/kg_core/ |
空间图谱与核心图谱辅助逻辑 |
app/schemas/ |
抽取 schema |
app/security.py、app/auth.py |
登录、令牌和权限相关逻辑 |
前端模块
| 路径 | 说明 |
|---|---|
admin-web/src/App.tsx |
管理后台主应用与路由 |
admin-web/src/api.ts |
API 客户端 |
admin-web/src/panels/plaza/ |
图谱广场、用户查询、手动抽取和 Super Agent |
admin-web/src/panels/acquisition/ |
数据源、批次和冲突工作台 |
admin-web/src/panels/review/ |
证据质量、字段审核、专家签核和资产库 |
admin-web/src/panels/modeling/ |
Schema、词表和健康检查 |
admin-web/src/panels/publish/ |
发布与回滚 |
admin-web/src/panels/system/ |
用户、权限、区域、通知、Agent 设置和日志 |
数据层
PostgreSQL 和 FalkorDB 承担不同职责:
- PostgreSQL:结构化管理数据、审核过程数据、用户权限、任务、来源、候选实体和证据。
- FalkorDB:图谱实体、关系、路线、资源、POI、空间索引和面向查询的图结构。
默认配置:
| 配置项 | 默认值 |
|---|---|
| PostgreSQL database | kg_admin |
| PostgreSQL schema | kg_admin_new2 |
| FalkorDB 业务图 | guiyang_new2 |
| FalkorDB 空间图 | guiyang_spatial_v1 |
构建过程
Dockerfile 使用多阶段构建:
- Node.js 阶段进入
admin-web/,执行npm ci和npm run build。 - Python 阶段安装
requirements.txt。 - 复制
app/、schema搭建/和前端构建产物到镜像。 - 容器启动
uvicorn app.main:app --host 0.0.0.0 --port 8000。
快照文件不会进入 API 镜像,它们由 docker-compose.yml 作为只读挂载提供给数据库容器。