Files
crypto_monitor/manual_trading_hub/使用说明.md
T
dekun 6a56928d59 feat(hub): add symbol archive with permanent 5m klines
Add /archive page, hub_symbol_archive.db, trade overlay, 4h background sync, and instance /api/hub/trades/archive. Document in hub-symbol-archive-kline.md with cross-links.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-06-07 22:51:48 +08:00

25 KiB
Raw Blame History

多账户交易中控 — 使用说明

本文档说明 manual_trading_hub 的架构、启动方式、界面操作与故障排查。中控聚合四所 持仓/条件单/余额/关键位/趋势计划监控 + 撤单/紧急全平,并提供 行情区 K 线币种档案(永久 K 线复盘)人工下单、关键位、策略交易(趋势回调 / 顺势加仓)、交易复盘 均在各实例网页操作(点监控卡片 「实例」)。行情区细则见 行情区说明.md;币种档案见 docs/hub-symbol-archive-kline.md


1. 架构总览

浏览器
  ├─ /monitor   监控区(持仓、关键位、趋势计划、全平)
  ├─ /market    行情区(K 线、技术指标、持仓价格线)
  ├─ /archive   币种档案(交易时间线 + 永久 5m K 线)
  ├─ /ai        AI 教练(四户今日总结 + 聊天)
  └─ /settings  系统设置(hub_settings.json

中控 hub.py(默认 :5100
  ├─ HTTP → 子代理 agent.py × N/status、/emergency/close-all
  └─ HTTP → 各实例 Flask/api/hub/monitor、/api/price_snapshot 等只读聚合)
组件 职责 默认端口(可在设置页改)
hub.py 聚合 UI、监控 API、全平 5100
agent.py 交易所只读状态、挂单/条件单查询与撤销 + 紧急市价全平 币安 15200、OKX 15201、Gate 15202、Gate趋势 15203
crypto_monitor_*.app 策略库、关键位、人工单、趋势预览/执行 币安 5001、Gate 5000、Gate趋势 5002、OKX 5004

1.1 四账户默认配置

id 名称 Flask Agent 监控能力(设置页勾选) 默认启用
0 币安 :5001 :15200 关键位
1 OKX :5004 :15201 关键位 + 趋势计划(建议) HUB_DISABLED_IDS=1,需用时在设置页启用)
2 Gate 训练 :5000 :15202 关键位
3 Gate 趋势 :5002 :15203 趋势计划(默认不勾关键位)
  • Gate 趋势户:默认只勾 监控趋势计划;一般不勾关键位(该户多用于趋势回调)。策略操作在实例 /strategy
  • 币安 / Gate 训练 / OKX:四所均已支持 策略交易;中控可同时勾 监控关键位 + 监控趋势计划(见 §4.2、§5)。
  • OKX:默认关闭;需要时在「系统设置」勾选启用,并去掉环境变量 HUB_DISABLED_IDS 中的 1

1.2 实例侧改动(最小)

crypto_monitor_* 仅增加:

  1. login_requiredhub_auth.request_allowed(支持请求头 X-Hub-Token)。
  2. 文件末尾 hub_bridge.install_on_app(...) 注册 /api/hub/*

业务逻辑、数据库、复盘页面 未改;复盘请打开各实例 /records(设置里的「复盘链接」)。


2. 环境准备

2.1 依赖安装

cd /opt/crypto_monitor/manual_trading_hub
python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt

2.2 鉴权令牌(推荐生产启用)

四实例 Flask 与中控、子代理需 同一密钥

变量 作用
HUB_BRIDGE_TOKEN 中控 → Flask 使用头 X-Hub-Token;各实例 hub_auth 校验
CONTROL_TOKEN 可与上相同;中控 → 子代理使用头 X-Control-Token

中控 hub.py 会读取 HUB_BRIDGE_TOKEN,若无则回退 CONTROL_TOKEN

开发本机可临时在各实例 .envAPP_AUTH_DISABLED=true,则 Flask 不校验令牌(仍建议子代理设 CONTROL_TOKEN 防误暴露)。

2.3 强制关闭某账户

# 在 manual_trading_hub/.env 中设置,或临时:
export HUB_DISABLED_IDS=1    # 默认即关闭 OKXid=1

与设置页「启用」取 关系:环境变量强制关闭时,网页勾选框会灰掉且无法启用。

2.4 Web 登录(反代公网强烈建议)

manual_trading_hub/.env 中配置:

变量 说明
HUB_USERNAME 登录用户名;未设且已设密码时默认为 admin
HUB_PASSWORD 非空即启用登录;所有页面与 API(除登录页、/api/ping/assets)须先登录
HUB_SESSION_SECRET 会话签名密钥(建议单独随机串)
HUB_COOKIE_SECURE 建议 true:仅 HTTPS 访问时 Cookie 带 SecureHTTP 内网 IP:5100 仍可登录
HUB_SESSION_DAYS 登录保持天数,默认 7
  • 登录页:http://<中控地址>:5100/login
  • 顶栏 退出 清除会话。
  • 域名(HTTPS内网 IPHTTP Cookie 不共用,需分别登录一次。

更多登录/Cookie 问题见 常见问题.md 第二节。

2.5 配置文件

  • 路径:manual_trading_hub/hub_settings.json(在网页 系统设置 → 保存设置 后写入)。
  • 未保存前使用 settings_store.py 内置默认四所地址。
  • 建议 不要 把含内网 IP 的 hub_settings.json 提交到公开仓库。
  • 环境变量模板:manual_trading_hub/.env.example;四实例模板中已补充 HUB_BRIDGE_TOKEN 说明。

3. 启动顺序(Ubuntu + PM2

原则:代码在 /opt/crypto_monitor,先四实例 Flask,再中控(一条 PM2 含 4 agent + hub)。环境见 docs/ubuntu-server.md

# 四所 Flask(示例:币安;其余三所同理)
cd /opt/crypto_monitor/crypto_monitor_binance
pm2 start ecosystem.config.cjs

# 中控 + 子代理
cd /opt/crypto_monitor/manual_trading_hub
pm2 start ecosystem.config.cjs
pm2 save

浏览器(本机或反代):

  • 监控区:http://127.0.0.1:5100/monitor
  • 行情区:http://127.0.0.1:5100/market
  • 币种档案:http://127.0.0.1:5100/archive
  • 系统设置:http://127.0.0.1:5100/settings

验收:

bash /opt/crypto_monitor/manual_trading_hub/scripts/verify_hub_deploy.sh
curl -s http://127.0.0.1:5100/api/ping

4. 页面操作说明

Chrome 桌面快捷方式图标来自站点 favicon / manifest(已配置统一品牌图),说明见 docs/shortcut-icon.md

4.1 监控区 /monitor

功能 说明
2×2 主界面 四所信息完整展示:余额、持仓表、委托/平仓、折叠委托单、下单监控、关键位、趋势/加仓摘要
全屏放大 点击卡片标题栏(非按钮区)→ 该所全屏:每币种一张实盘风格持仓卡(趋势持仓显示来源: 趋势回调计划风险%程序监控·止盈价盈亏比,与实例策略页一致);独立卡片:关键位下单监控趋势回调(单计划 两列:左=币种基本信息与 3×2 指标,右=补仓计划明细,底=保本偏移% 可编辑 + 保本移交 / 结束计划(中控直接调实例,与 /strategy 一致)、快照可用/计划保证金/杠杆)、顺势加仓
委托单折叠 仅「委托单」区块默认折叠;展开状态存浏览器本地,5 秒刷新不重置
条件单 / 委托 每个持仓下方展示交易所 条件单(默认折叠)与 普通委托;数据来自子代理实时拉取(币安含 Algo 通道)
撤单 条件单区内单笔「撤单」或「撤销全部」;经中控 POST /api/orders/{id}/cancelcancel-symbol
挂止盈止损 持仓行 「委托」:弹窗填止损/止盈价 → 先撤该合约全部条件单,再挂新 TP/SL(币安 / OKX / Gate / Gate趋势 四所统一,逻辑与各实例 .env 参数一致)
平仓 持仓行「平仓」:仅平该方向仓位(子代理市价减仓)
机器人单 来自实例 /api/hub/monitororder_monitorsactive),为本地监控计划,不等于交易所条件单
关键位 capabilitieskey 的户;展示门控摘要(/api/price_snapshot
趋势计划 仅当该户勾选 监控趋势计划 时展示 trend_pullback_plansactive
实例 / 复盘 「实例」「策略交易」「复盘」经中控签发 SSO 链接(默认 2h、单次)打开,免输实例 APP_USERNAME/PASSWORD;直链实例 IP/域名仍走 /login云服务器云服务器部署说明.md;局域网/反代见 局域网与反代部署说明.md
关键位列表 来自 /api/hub/monitor + /api/price_snapshotFlask 未连通时卡片提示原因;Gate 趋势户无关键位块
该户全平 POST 子代理 /emergency/close-all,仅平该 API Key 仓位
全局紧急全平 对所有已启用户依次全平(不含 HUB_DISABLED_IDS 强制关闭的 id
自动刷新 默认每 5 秒请求 /api/monitor/board

持仓数据以 子代理 ccxt 为准;关键位/趋势/机器人单以 Flask 数据库 为准。若 Flask 未启动,卡片仍会显示 agent 持仓,但下方策略信息可能为空或报错。

4.2 行情区 /market

功能 说明
K 线 选择已启用交易所 + 币种 + 周期;按需拉取,本地 data/hub_kline.db 缓存(默认保留 15 天)
周期 1m 5m 15m 1h 2h 4h 12h 1d 1w
加载 / 强制刷新 普通加载优先缓存;强制刷新重拉并覆盖缓存
从监控跳转 点击持仓合约名带入品种,并显示入场/止损/止盈/委托与 K 线价格线
技术指标 可选 EMA 21/55、MACD、RSI
快捷键 F 全屏/退出;全屏时 Esc 退出;数字键切换周期(见 行情区说明.md
自动刷新 约 5 秒更新最新 OHLCV

数据经中控 → 各实例 GET /api/hub/ohlcvhub_ohlcv_lib)。升级 hub 与四实例 Flask 后请 强刷浏览器;异常 K 线可点 强制刷新

4.2.1 币种档案 /archive

功能 说明
列表 一所一币一行;数据来自四所 trade_recordsGET /api/hub/trades/archive
筛选 交易所、有盈利单、有亏损单、犯病/情绪标签(中控 overlay,不上传图片)
明细 交易时间线;可编辑备注与犯病/情绪标签
K 线 独立库 data/hub_symbol_archive.db;仅存 5m 真源,15m/1h/4h 聚合;默认 Tab 15m
建档 最早开仓向前 30 天 5m 种子;之后每 4h 增量(Hub 后台 + 可点「同步」)
视窗 持仓过程(锚平仓)/ 进场决策(锚开仓);支持时间输入跳转

与行情区 hub_kline.db15 天滚动)分离,建档起 只增不删。细则见 docs/hub-symbol-archive-kline.md

4.3 AI 教练 /ai

功能 说明
今日总结 聚合四户当日平仓(trade_records)、持仓浮盈亏、连接状态;未启用账户标注 未监控;语气偏冷、台账式
生成 点「生成今日总结」;结果写入 hub_ai_summaries.json(同目录备份)
聊天 单会话持续对话,直到点 「新开对话」;口语化、安慰体贴、轻修正(非说教)
模型 与四实例相同 .env(默认 AI_PROVIDER=openai + OPENAI_*;改 ollama 走本机),见 AI教练说明.md
与实例复盘 深度单笔 journal 复盘仍在各所 /records;中控不做重复

依赖四实例 GET /api/hub/trades/todayhub_bridge);升级代码后需 重启四所 Flask

4.4 系统设置 /settings

可用:打开 http://127.0.0.1:5100/settings ,修改表格后点 保存设置 即写入 hub_settings.json重新加载 从磁盘/默认再读(会重新套用 HUB_DISABLED_IDS)。保存后监控区立即使用新 URL/启用状态,无需重启 hub

下单、关键位、策略交易:请在监控卡片点击 「实例」「策略交易」SSO),进入各 crypto_monitor_* 网页(/trade/key_monitor/strategy/strategy/records 等)。中控 提供下单区;策略交易记录 仅在实例顶栏查看(见 策略交易说明.md §五)。

含义
启用 是否参与监控与全局全平;被 HUB_DISABLED_IDS 锁定的无法勾选
显示名 监控卡片标题
Flask URL 实例根地址,如 http://127.0.0.1:5001
Agent URL 子代理根地址,如 http://127.0.0.1:15200
复盘链接 一般为 {Flask}/records
监控关键位 勾选后卡片展示 关键位 列表 + 门控价(读 Flask /api/price_snapshot
监控趋势计划 勾选后卡片展示 趋势回调 运行中计划(trend_pullback_plans active
id HUB_DISABLED_IDS、全平 API 路径中的 id 对应;新增户勿与已有 id 重复
  • 保存设置:写入 hub_settings.json,重启 hub 后仍生效。
  • 添加交易所:见下文 §4.5(须先自建 Flask + agent,再在中控登记)。
  • :从列表移除(保存后生效)。

能力与「策略交易」的关系(重要)

能力勾选 中控监控区 策略交易(趋势回调 / 顺势加仓)
监控关键位 显示关键位块 不控制;在实例页 /key_monitor
监控趋势计划 显示趋势计划块 不控制;在实例页 /strategy 左栏操作
均未勾选 仅持仓、余额、机器人单 仍可在实例网页使用策略交易

四所 Flask 均已注册 hub_bridgehas_trend=true,勾选「监控趋势计划」后才会从 /api/hub/monitor 拉取趋势数据。修改勾选后 保存即可,须 重启对应 Flask 仅在你刚升级了 hub_bridge 相关代码时。


4.5 增加账户(例如再挂一个 Gate)

中控 不会 自动启动进程,也 保存交易所 API Key。新增一户 = 复制/新建一套实例目录 + 独立 .env + 新端口 Flask/agent + 在中控登记一行

4.5.1 端口勿冲突(示例)

用途 目录(示例) Flask APP_PORT Agent PORT
Gate 训练(已有) crypto_monitor_gate 5000 15202
Gate 趋势(已有) crypto_monitor_gate_bot 5002 15203
新增 Gate 子账户 复制为 crypto_monitor_gate_2 5005(自定) 15204(自定)

agentPORT 与 Flask 的 APP_PORT 必须不同;且不要与币安 5001、OKX 5004、中控 5100 等占用端口相同。

4.5.2 新建实例目录

  1. 复制整个 crypto_monitor_gate 到新目录(仓库内副本或 /opt/ 下均可)。
  2. 在新目录:cp .env.example .env,至少修改:
    • APP_PORT → 新 Flask 端口(如 5005
    • DB_PATH → 独立库(如 crypto_gate2.db),与 5000/5002 共用 crypto.db
    • GATE_API_KEY / GATE_API_SECRET该子账户 密钥
    • HUB_BRIDGE_TOKEN → 与中控、其它实例 相同
  3. 安装 venv 与依赖(bash /opt/crypto_monitor/deploy/setup_env.sh --only gate 或按 Gate 部署文档),启动:
cd /opt/crypto_monitor/crypto_monitor_gate_2
pm2 start ecosystem.config.cjs
  1. 在中控 ecosystem.config.cjs 增加对应 agent,或单独 run_agent.sh 配置后 pm2 restart(勿与已有 agent 端口冲突)。

验收:curl http://127.0.0.1:5005/login 能开页;curl http://127.0.0.1:15204/status 返回 ok

4.5.3 在中控登记

  1. 打开 系统设置添加交易所(或手改 manual_trading_hub/hub_settings.json)。
  2. 填写 Flask URLAgent URLid(如 4)、显示名
  3. 能力建议:
    • 训练/关键位户:监控关键位 + 监控趋势计划(若也要在中控看趋势计划);
    • 纯趋势户:只勾 监控趋势计划
  4. 勾选 启用保存设置
  5. 监控区 应出现新卡片;点 实例 进入该户网页做下单与 策略交易

PM2:仓库 ecosystem.config.cjs 默认只有四 agent;第五户需自行 pm2 start 或手工终端,与是否改 hub 源码无关。


5. 能力矩阵(监控展示,建议勾选)

账户 监控关键位 监控趋势计划 策略交易(实例页)
币安 ✓ 建议 ✓ 建议 /strategy
OKX ✓ 建议 ✓ 建议 /strategy
Gate 训练 ✓ 建议 ✓ 建议 /strategy
Gate 趋势 —(通常不勾) /strategy

「建议」表示中控卡片展示对应块;不勾 仍可在该实例网页使用关键位或策略交易。


6. HTTP API 摘要(中控)

访问控制:

  • IP:默认允许本机与 RFC1918 私网(HUB_TRUST_LAN=true);公网 IP 直连返回 403。
  • 登录:设置 HUB_PASSWORD 后须用户名+密码登录(HUB_USERNAME,未设时默认 admin);反代到公网时务必设置
方法 路径 说明
GET /api/settings 读取配置
POST /api/settings 保存配置
GET /api/monitor/board 监控聚合
POST /api/close/{id} 单户全平
POST /api/close-all 全局全平,body 可选 exclude_ids
GET /api/auth/status 是否需登录、是否已登录
POST /api/auth/login body {"username":"...","password":"..."}
POST /api/auth/logout 退出
GET /api/ping 版本与健康检查(免登录
GET /api/chart/meta 行情区:交易所、周期、limit
GET /api/chart/ohlcv 行情区 K 线(exchange_keysymboltimeframe、可选 refresh=1
GET /api/archive/meta 币种档案:周期、同步间隔
GET /api/archive/list 币种列表(筛选 query
GET /api/archive/detail 单币种交易时间线
GET /api/archive/ohlcv 档案 K 线视窗
PATCH /api/archive/trade/{exchange_key}/{trade_id} 犯病/情绪标签与备注
POST /api/archive/sync 立即同步四所交易与 K 线

已移除的 /api/trade/* 若被旧缓存页面请求,返回 410 并提示前往各实例网页。

实例侧(中控只读;下单/关键位/趋势在实例网页):

路径 说明
/api/hub/ping 连通与能力
/api/hub/monitor 关键位、机器人单、趋势计划
/api/hub/ohlcv 行情区 OHLCV(ccxt 拉取,供中控聚合缓存)
/api/hub/trades/archive 币种档案:近 N 天已平仓(days / limit

7. 环境变量速查

中控 hub.py

变量 默认 说明
HUB_HOST 0.0.0.0 监听地址
HUB_PORT 5100 监听端口
HUB_BRIDGE_TOKEN Flask 桥接令牌;可同 CONTROL_TOKEN
HUB_DISABLED_IDS 1 逗号分隔,强制关闭的账户 id
HUB_TRUST_LAN true false 时仅本机可访问中控页面
HUB_USERNAME admin 登录用户名(仅当已设密码时生效)
HUB_PASSWORD (空) 非空即启用 Web 登录
HUB_SESSION_SECRET 用户名+密码 会话 Cookie 签名密钥
HUB_COOKIE_SECURE false HTTPS 反代建议 true(仅 HTTPS 发 Secure CookieHTTP 内网 IP 仍可登)
HUB_SESSION_DAYS 7 登录保持天数
HUB_KLINE_RETENTION_DAYS 15 行情区 K 线库保留天数
HUB_KLINE_DB_PATH data/hub_kline.db K 线 SQLite 路径
HUB_ARCHIVE_DB_PATH data/hub_symbol_archive.db 币种档案永久 K 线库
HUB_ARCHIVE_SYNC_INTERVAL_SEC 14400 档案 K 线后台同步间隔(秒)
HUB_ARCHIVE_TRADE_DAYS 365 同步交易记录回看天数
HUB_ARCHIVE_TRADE_LIMIT 2000 单所同步交易条数上限

子代理 agent.py

变量 说明
EXCHANGE binance / okx / gate
PORT / HOST 监听
CONTROL_TOKEN 与中控一致时必填头 X-Control-Token

各实例 Flask

变量 说明
HUB_BRIDGE_TOKEN 与中控一致
APP_AUTH_DISABLED true 时跳过登录与令牌(仅建议本机调试)

8. 安全与边界

  1. 中控不下单:开仓、关键位、趋势回调仅在各实例网页操作。
  2. 全平为市价减仓:监控区全平不可撤销,操作前二次确认。
  3. 子代理建议只监听 127.0.0.1,不要对局域网暴露 API Key 通道。
  4. 公网暴露 hub:必须设置 HUB_USERNAME + HUB_PASSWORDHTTPS 反代建议 HUB_COOKIE_SECURE=true;亦可 HUB_HOST=127.0.0.1 仅本机监听 + 反代。
  5. 复盘不在中控:时间筛选、导出 CSV、编辑笔记仍在各实例 /records
  6. OKX 默认关:避免未部署 OKX 时监控卡片持续报错。

9. 故障排查(速查)

完整实录(含 api_trade_keymultipart、git 版本、PM2 等)见 常见问题.md

现象 可能原因 处理
监控卡片「子代理不可用」 agent 未启动或端口错 检查 Agent URLpm2 restart agent
无关键位/趋势信息 Flask 未起或 hub_bridge 未加载 启动 crypto_*curl .../api/hub/ping
全平 401 CONTROL_TOKEN 与中控不一致 HUB_BRIDGE_TOKEN 对齐
OKX 始终灰色 HUB_DISABLED_IDS=1 改掉环境变量并在设置页启用
打开即跳转登录 已设 HUB_PASSWORD 正常;访问 /login
域名能登、IP:5100 不能 Secure Cookie + HTTP 见常见问题 §2.1;或分别登录
添加关键位报错 / SyntaxError 旧前端或旧 hub 代码 强刷浏览器;git pull + verify_hub_deploy.sh
curl /api/ping 非 JSON hub 未启动 pm2 restart manual-trading-hub
K 线只有约 300 根 旧版未分页 git pull 四实例 + hub,强制刷新
12h 周期异常 无原生 12h 或旧缓存 强制刷新;见 行情区说明.md

运维脚本(在 manual_trading_hub 目录执行):

脚本 作用
scripts/fix_hub_deps.sh 安装依赖(含 python-multipart
scripts/verify_hub_deploy.sh 检查代码版本与 ping
scripts/fix_env_crlf.sh 修复 .env 的 CRLF 导致 agent 起不来

手动探测实例桥接:

curl -sS -H "X-Hub-Token: 你的令牌" http://127.0.0.1:5001/api/hub/ping

10. 与旧版 README 的差异

早期中控 仅监控 + 全平,使用环境变量 HUB_AGENTS 列表。当前版本改为:

  • hub_settings.json(或内置默认)管理四所 URL 与能力;
  • 三页 UI:监控 / 行情 / 设置;
  • 通过 hub_bridge 只读聚合监控数据。

子代理 agent.py 仍负责持仓与全平;HUB_AGENTS 环境变量在新版 hub 中 不再使用(以设置文件为准)。

PM2 守护

cd /opt/crypto_monitor/manual_trading_hub
python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
cp .env.example .env
pm2 start ecosystem.config.cjs    # 一次启动 4 个 agent + manual-trading-hub
pm2 save && pm2 startup

快捷:bash scripts/pm2_hub.sh start|restart|logs(同样 hub+agent 一起)。

更细的安装顺序、反代、验收见 《部署文档.md》PM2 见 scripts/后台运行-Ubuntu.md


11. 日常推荐流程

  1. 启动四所 agent + FlaskOKX 按需)。
  2. 启动 hub.py,打开监控区确认持仓与关键位门控正常。
  3. 看 K 线 → 行情区 或监控区点击合约名跳转;异常图表点 强制刷新
  4. 开仓、关键位、趋势 → 点击监控卡片「实例」进入对应 Flask。
  5. 复盘、导出记录 → 点击「复盘」进入 /records
  6. 异常行情 → 单户全平或全局紧急全平。

增加账户步骤见 §4.4;无需改 hub.py 源码,但须该户 Flask 已 git pull重启hub_bridge + has_trend + ohlcv),且 agent 已部署。


12. 文档索引

文档 内容
使用说明.md 本文
行情区说明.md K 线周期、缓存、快捷键、API
docs/hub-symbol-archive-kline.md 币种档案、永久 5m、建档与同步
部署文档.md Ubuntu / PM2 / 反代
常见问题.md 故障实录与排障
README.md 速览
.env.example 环境变量模板
scripts/后台运行-Ubuntu.md PM2 常驻
docs/ubuntu-server.md Ubuntu 环境总览