跳到主要内容

系统架构

Ithiltir Dash 是单实例应用。根入口只启动一个 HTTP 进程,该进程装配 API、SPA、主题资源、安装脚本、节点资产分发和后台服务。

运行边界

组件责任
cmd/dash进程入口、配置加载、依赖装配、迁移入口和关闭流程
HTTP 服务挂载 /api/theme/deploy 和 SPA
PostgreSQL + TimescaleDB持久化指标历史、流量事实、节点元数据、告警规则、告警通知 outbox 和系统设置
Redis默认保存会话、热点快照和告警运行时状态
进程内内存节点鉴权索引和易失 Agent 更新请求;--no-redis 时承接会话和热点运行时状态
Ithiltir-node上报指标和静态主机信息;Windows runner 启动时接收更新 manifest
Web UI读取看板数据并提交管理操作

HTTP 面

前缀作用
/api/auth登录、续期、登出、会话撤销
/api/versionDash 版本和打包携带的节点版本
/api/front看板读取
/api/metrics历史指标和在线率查询
/api/statistics统计访问策略和流量统计查询
/api/node节点上报和节点身份读取
/api/admin管理台写操作
/theme当前主题 CSS、主题 manifest 和预览图
/deploy安装脚本和节点发布资产
/SPA

数据流

  1. Ithiltir-node 通过 /api/node/* 上报指标和静态主机信息。
  2. 指标上报成功响应可以包含更新 manifest。
  3. PostgreSQL + TimescaleDB 保存持久化历史、流量事实、配置和告警通知 outbox。
  4. Redis 或进程内内存保存热点快照、会话和告警运行时状态。
  5. 后台服务评估告警、发送队列通知并汇总流量数据。

状态和保留策略

  • 默认启动依赖 PostgreSQL 和 Redis。
  • --no-redis 会把 Redis 承载的运行时状态改用进程内内存。
  • 节点鉴权和待下发 Agent 更新请求使用进程内内存,不走 Redis。
  • 告警评估读取热点快照。内置离线和 RAID 规则来自快照新鲜度和上报 RAID 健康状态。
  • 告警服务启动后 1 分钟内不会新开告警事件。
  • 告警通知 payload 存入 PostgreSQL outbox,并由带租约的重试 worker 发送。
  • 数据库历史保留默认 45 days;普通监控用 database.retention_days,流量 5 分钟事实表用 database.traffic_retention_days
  • 流量 lite 模式保存月度入/出总量和估算峰值;billing 模式额外维护 5 分钟事实、日汇总、P95、覆盖率和月度快照。
  • 历史指标默认不对游客公开。history_guest_access_mode=by_node 时,只对游客可见节点开放。
  • 流量统计是否对游客公开由流量设置控制,并仍受节点可见性限制。

鉴权边界

区域鉴权
/api/auth/login管理员密码
/api/auth/refresh/api/auth/logoutrefresh cookie + X-CSRF-Token
/api/front/*/api/metrics/*/api/statistics/*Bearer 可选;匿名请求按系统可见性设置过滤
/api/node/*X-Node-Secret
/api/admin/*Authorization: Bearer <access_token>

前端和反向代理

前端和后端必须保持同源路径。生产反向代理应把 /api/theme/deploy 转给 Dash 后端,/ 保持为 Dash SPA。app.public_url 必须是根路径 URL,不支持 /dash 这类路径前缀。