This commit is contained in:
dekun
2026-05-25 12:56:39 +08:00
parent 6ec5a2caf1
commit 3f1e2b17a1
4 changed files with 267 additions and 1 deletions
@@ -0,0 +1,264 @@
# 本地数据备份与迁移到云服务器
本文说明如何把 **本机** 上运行的 `crypto_monitor`(四实例 + 中控)的**业务数据**迁到 **云 VPS**,并正确改配置。
**不迁移** 本机 Python 虚拟环境(`.venv`),云上重新 `pip install` 即可。
相关:[云服务器部署说明.md](./云服务器部署说明.md) · [部署文档.md](./部署文档.md)
---
## 一、要迁什么、不迁什么
### 必须迁移(业务数据)
| 路径(每个实例目录下) | 内容 |
|------------------------|------|
| `crypto.db`(或 `.env``DB_PATH` 指向的文件) | 监控单、关键位、交易记录、复盘、运行时开关等 **SQLite 全库** |
| `static/images/`(或 `UPLOAD_DIR` | 上传图、复盘截图等 |
| `static/images/order_charts/`(或 `ORDER_CHART_DIR` | 订单 K 线图(若开启) |
四个实例 **各有一份独立库**
- `crypto_monitor_binance/crypto.db`
- `crypto_monitor_okx/crypto.db`
- `crypto_monitor_gate/crypto.db`
- `crypto_monitor_gate_bot/crypto.db`
### 中控额外迁移
| 路径 | 内容 |
|------|------|
| `manual_trading_hub/hub_settings.json` | 账户 URL、启用状态、能力勾选(网页「系统设置」保存的文件) |
### 不要直接覆盖拷贝(需在云上重写)
| 文件 | 说明 |
|------|------|
| 各目录 `.env` | 含 API 密钥:可在云上**手工新建**,从本机抄密钥,但须改 **`flask_url`、代理、公网相关项**(见下文) |
| `.venv/``__pycache__/` | 云上重建 |
| PM2 日志 | 无需迁 |
### 可选
- 本机 `manual_trading_hub/.env` 里的 `HUB_BRIDGE_TOKEN``HUB_PASSWORD` 等:记下后在云上填入,**不要**把含密钥的 `.env` 发到公开网盘。
---
## 二、迁移前准备(本地)
### 1. 停服务(避免数据库半写入)
```bash
# 本机:停中控与子代理
cd manual_trading_hub
pm2 stop manual-trading-hub manual-agent-binance manual-agent-okx manual-agent-gate manual-agent-gate-bot
# 本机:停四个 Flask(进程名以你 pm2 list 为准)
pm2 stop crypto_okx crypto_binance crypto_gate crypto_gate_bot
# 或各目录 ecosystem 里的名字
```
未用 PM2 时,结束对应 Python/Flask 进程后再备份。
### 2. 确认数据库文件位置
各实例目录下查看 `.env``DB_PATH`(默认 `crypto.db`)。若存在 `crypto.db-wal``crypto.db-shm`**必须先停服务** 再备份。
---
## 三、本地备份(推荐用自带脚本)
每个实例目录执行(会备份 **库 + static/images**):
```bash
cd crypto_monitor_okx
bash scripts/backup_data.sh
# 默认输出到 /root/backups/crypto_monitor_okx/YYYY-MM-DD/
# 本机可改环境变量:BACKUP_ROOT=~/crypto_backups bash scripts/backup_data.sh
```
`crypto_monitor_binance``crypto_monitor_gate``crypto_monitor_gate_bot` **各执行一次**
脚本产物示例:
```text
~/crypto_backups/crypto_monitor_okx/2026-05-21/
crypto.db
static_images.tar.gz
manifest.txt
```
### 手工打包(不用脚本时)
在仓库根目录示例:
```bash
BACKUP=~/crypto_migrate_$(date +%Y%m%d)
mkdir -p "$BACKUP"
for dir in crypto_monitor_okx crypto_monitor_binance crypto_monitor_gate crypto_monitor_gate_bot; do
tar -czf "$BACKUP/${dir}.tar.gz" \
-C "$dir" crypto.db static/images 2>/dev/null || \
tar -czf "$BACKUP/${dir}.tar.gz" -C "$dir" crypto.db
done
cp manual_trading_hub/hub_settings.json "$BACKUP/" 2>/dev/null || true
```
---
## 四、上传到云服务器
在**你电脑**上(把 `USER``云IP` 换成实际值):
```bash
# 打包整个备份目录
tar -czf crypto_migrate.tar.gz -C ~ crypto_backups # 或你的 BACKUP 路径
scp crypto_migrate.tar.gz USER@云IP:/tmp/
scp manual_trading_hub/hub_settings.json USER@云IP:/tmp/ # 若单独备份
```
大文件可用 **rsync**(支持断点续传):
```bash
rsync -avz --progress ~/crypto_backups/ USER@云IP:/tmp/crypto_backups/
```
---
## 五、云上恢复数据
假设代码已在 `/opt/crypto_monitor``git clone``rsync` 代码均可,**代码与数据分开**)。
```bash
ssh USER@云IP
cd /opt/crypto_monitor
# 解压(若用 scp 单包)
tar -xzf /tmp/crypto_migrate.tar.gz -C /tmp
# 按实例恢复(示例:OKX
pm2 stop crypto_okx 2>/dev/null || true
cp /tmp/crypto_backups/crypto_monitor_okx/2026-05-21/crypto.db crypto_monitor_okx/crypto.db
tar -xzf /tmp/crypto_backups/crypto_monitor_okx/2026-05-21/static_images.tar.gz -C crypto_monitor_okx/
# 若 tar 里是 static/images 目录结构,确认解压后路径为 crypto_monitor_okx/static/images
# 对其余三所重复同样步骤
```
恢复中控设置:
```bash
cp /tmp/hub_settings.json manual_trading_hub/hub_settings.json
# 或解压备份里带的 hub_settings.json
```
**权限**(避免 Flask 写库失败):
```bash
sudo chown -R 运行用户:运行用户 /opt/crypto_monitor/crypto_monitor_*/crypto.db
sudo chown -R 运行用户:运行用户 /opt/crypto_monitor/crypto_monitor_*/static/images
```
---
## 六、云上必须改的配置(比迁移本身更重要)
数据文件原样拷过去不够,**.env 与 hub_settings 要按云环境改**。
### 1. 各实例 `crypto_monitor_*/.env`
从本机**抄写** API 密钥等,并调整:
| 项 | 本地常见 | 云上建议 |
|----|----------|----------|
| `OKX_SOCKS_PROXY` 等 | `socks5h://127.0.0.1:1080` | **留空**(直连),除非云上仍访问不了交易所 |
| `APP_AUTH_DISABLED` | 可能为 true(本机) | **false** 或未设置 |
| `APP_USERNAME` / `APP_PASSWORD` | 可有 | 设统一强密码(直链登录) |
| `HUB_BRIDGE_TOKEN` | 有 | 与中控 **完全一致** |
### 2. `manual_trading_hub/.env`
见 [云服务器部署说明.md](./云服务器部署说明.md)`HUB_PASSWORD``HUB_BRIDGE_TOKEN``HUB_COOKIE_SECURE=true` 等。
### 3. `hub_settings.json` 里的 URL
**必须**改成浏览器能打开的地址:
| 字段 | 云上 |
|------|------|
| `flask_url` | `https://okx.你的域名.com`(每实例不同子域) |
| `agent_url` | `http://127.0.0.1:15201`(保持本机,勿写公网 IP |
本机若是 `http://192.168.x.x:5004``http://127.0.0.1:5004`,上云后**一定要改**,否则「打开实例」会指错地址。
---
## 七、云上启动与验收
```bash
# 依赖(各目录 venv + manual_trading_hub
# 见 云服务器部署说明.md、部署文档.md
cd /opt/crypto_monitor
# 先四实例 Flask,再 manual_trading_hub ecosystem
pm2 start ...
pm2 save
```
验收:
- [ ] 各实例网页能登录,**交易记录 / 关键位 / 监控单** 与本地一致
- [ ] 复盘图片能显示(`static/images` 路径正确)
- [ ] 中控监控卡片能读到持仓;`hub_settings` 账户 URL 正确
- [ ] 本机已 **停止** 或不再用同一 API Key 同时跑两套(避免重复下单)
---
## 八、迁移策略建议
### 方案 A:一次性切换(简单)
1. 本地停 PM2 → 备份 → 上传 → 云上恢复 → 改配置 → 只跑云端。
2. 适合能接受 **短暂停机**(几十分钟)。
### 方案 B:先云后停本地(稳一点)
1. 云上先部署代码、空库跑通;
2. 临近切换时再备份本地**最新**库覆盖云上;
3. 切换时刻停本地、启云上。
4. 减少「备份到上线」之间的数据空窗。
### 注意
- **同一交易所 API Key 不要本地和云上同时自动交易**,以免重复挂单。
- 迁移后第一次在云上打开,建议先看监控单、持仓是否与预期一致,再放开自动逻辑。
---
## 九、常见问题
**Q:只拷 `crypto.db` 不够吗?**
- 复盘、上传相关功能还依赖 `static/images`;建议库 + 图片一起迁。
**Q:迁移后 OKX 监控单没了?**
- 查是否拷错目录(四所各一个库)、或恢复后用了空库路径(`DB_PATH` 不一致)。
**Q:图片 404**
- 检查 `static/images` 是否解压到实例目录下;数据库里路径若为相对路径,一般与目录结构一致即可。
**Q:本地还用 SOCKS,云上要不要?**
- 云上通常 **不需要** SSH 隧道;见 [云服务器部署说明.md](./云服务器部署说明.md) 与此前说明:直连稳定后去掉 `*_SOCKS_PROXY`
---
## 十、相关脚本
各实例目录:
```bash
bash scripts/backup_data.sh
```
环境变量:`BACKUP_ROOT``BACKUP_RETENTION_DAYS``BACKUP_INSTANCE`(见脚本内注释)。