Files
exchange_monitor_sync/sync/manager.py

158 lines
5.8 KiB
Python
Raw Normal View History

2025-12-02 22:05:54 +08:00
import asyncio
from loguru import logger
import signal
import sys
2025-12-02 22:36:52 +08:00
import time
2025-12-03 23:53:07 +08:00
import json
2025-12-03 14:40:14 +08:00
from typing import Dict
2025-12-04 15:40:19 +08:00
import utils.helpers as helpers
2025-12-02 22:05:54 +08:00
2025-12-03 23:53:07 +08:00
from utils.redis_client import RedisClient
2025-12-02 22:05:54 +08:00
from config.settings import SYNC_CONFIG
2025-12-03 23:53:07 +08:00
from .position_sync import PositionSyncBatch
from .order_sync import OrderSyncBatch # 使用批量版本
from .account_sync import AccountSyncBatch
2025-12-03 14:40:14 +08:00
from utils.redis_batch_helper import RedisBatchHelper
2025-12-03 23:53:07 +08:00
from config.settings import COMPUTER_NAMES, COMPUTER_NAME_PATTERN
from typing import List, Dict, Any, Set, Optional
2025-12-02 22:05:54 +08:00
class SyncManager:
2025-12-03 14:40:14 +08:00
"""同步管理器(完整批量版本)"""
2025-12-02 22:05:54 +08:00
def __init__(self):
self.is_running = True
2025-12-03 23:53:07 +08:00
self.redis_client = RedisClient()
2025-12-02 22:05:54 +08:00
self.sync_interval = SYNC_CONFIG['interval']
2025-12-03 14:40:14 +08:00
# 初始化批量同步工具
self.redis_helper = None
2025-12-02 22:05:54 +08:00
# 初始化同步器
self.syncers = []
if SYNC_CONFIG['enable_position_sync']:
2025-12-03 14:40:14 +08:00
position_sync = PositionSyncBatch()
self.syncers.append(position_sync)
logger.info("启用持仓批量同步")
2025-12-02 22:05:54 +08:00
if SYNC_CONFIG['enable_order_sync']:
2025-12-03 14:40:14 +08:00
order_sync = OrderSyncBatch()
self.syncers.append(order_sync)
logger.info("启用订单批量同步")
2025-12-02 22:05:54 +08:00
if SYNC_CONFIG['enable_account_sync']:
2025-12-03 14:40:14 +08:00
account_sync = AccountSyncBatch()
self.syncers.append(account_sync)
logger.info("启用账户信息批量同步")
2025-12-02 22:05:54 +08:00
2025-12-02 22:36:52 +08:00
# 性能统计
self.stats = {
2025-12-03 14:40:14 +08:00
'total_syncs': 0,
2025-12-02 22:36:52 +08:00
'last_sync_time': 0,
2025-12-03 14:40:14 +08:00
'avg_sync_time': 0,
'position': {'accounts': 0, 'positions': 0, 'time': 0},
'order': {'accounts': 0, 'orders': 0, 'time': 0},
'account': {'accounts': 0, 'records': 0, 'time': 0}
2025-12-02 22:36:52 +08:00
}
2025-12-02 22:05:54 +08:00
# 注册信号处理器
signal.signal(signal.SIGINT, self.signal_handler)
signal.signal(signal.SIGTERM, self.signal_handler)
async def start(self):
"""启动同步服务"""
2025-12-03 14:40:14 +08:00
logger.info(f"同步服务启动,间隔 {self.sync_interval}")
2025-12-02 22:05:54 +08:00
while self.is_running:
try:
2025-12-02 22:36:52 +08:00
2025-12-03 14:40:14 +08:00
# 获取所有账号(只获取一次)
2025-12-04 19:44:22 +08:00
accounts = self.redis_client.get_accounts_from_redis()
2025-12-02 22:36:52 +08:00
2025-12-03 14:40:14 +08:00
if not accounts:
logger.warning("未获取到任何账号,等待下次同步")
await asyncio.sleep(self.sync_interval)
continue
2025-12-04 15:40:19 +08:00
# return
2025-12-03 23:53:07 +08:00
self.stats['total_syncs'] += 1
sync_start = time.time()
2025-12-03 14:40:14 +08:00
logger.info(f"{self.stats['total_syncs']}次同步开始,共 {len(accounts)} 个账号")
2025-12-03 23:53:07 +08:00
# 执行所有同步器
2025-12-04 15:40:19 +08:00
tasks = [syncer.sync_batch(accounts) for syncer in self.syncers]
2025-12-03 23:53:07 +08:00
await asyncio.gather(*tasks, return_exceptions=True)
2025-12-02 22:05:54 +08:00
2025-12-03 14:40:14 +08:00
# 更新统计
sync_time = time.time() - sync_start
self._update_stats(sync_time)
2025-12-02 22:36:52 +08:00
2025-12-03 14:40:14 +08:00
logger.info(f"同步完成,总耗时 {sync_time:.2f} 秒,等待 {self.sync_interval}")
2025-12-02 22:05:54 +08:00
await asyncio.sleep(self.sync_interval)
except asyncio.CancelledError:
logger.info("同步任务被取消")
break
except Exception as e:
logger.error(f"同步任务异常: {e}")
2025-12-04 15:40:19 +08:00
# 获取完整的错误信息
import traceback
error_details = {
'error_type': type(e).__name__,
'error_message': str(e),
'traceback': traceback.format_exc()
}
logger.error("完整堆栈跟踪:\n{traceback}", traceback=error_details['traceback'])
2025-12-03 14:40:14 +08:00
await asyncio.sleep(30)
2025-12-03 23:53:07 +08:00
2025-12-03 14:40:14 +08:00
def _update_stats(self, sync_time: float):
"""更新统计信息"""
self.stats['last_sync_time'] = sync_time
self.stats['avg_sync_time'] = (self.stats['avg_sync_time'] * 0.9 + sync_time * 0.1)
# 打印详细统计
stats_lines = [
f"=== 第{self.stats['total_syncs']}次同步统计 ===",
f"总耗时: {sync_time:.2f}秒 | 平均耗时: {self.stats['avg_sync_time']:.2f}"
]
if self.stats['position']['accounts'] > 0:
stats_lines.append(
f"持仓: {self.stats['position']['accounts']}账号/{self.stats['position']['positions']}"
f"/{self.stats['position']['time']:.2f}"
)
if self.stats['order']['accounts'] > 0:
stats_lines.append(
f"订单: {self.stats['order']['accounts']}账号/{self.stats['order']['orders']}"
f"/{self.stats['order']['time']:.2f}"
)
if self.stats['account']['accounts'] > 0:
stats_lines.append(
f"账户: {self.stats['account']['accounts']}账号/{self.stats['account']['records']}"
f"/{self.stats['account']['time']:.2f}"
)
logger.info("\n".join(stats_lines))
def signal_handler(self, signum, frame):
"""信号处理器"""
logger.info(f"接收到信号 {signum},正在关闭...")
self.is_running = False
2025-12-02 22:36:52 +08:00
2025-12-02 22:05:54 +08:00
async def stop(self):
"""停止同步服务"""
self.is_running = False
2025-12-03 14:40:14 +08:00
# 关闭所有数据库连接
for syncer in self.syncers:
if hasattr(syncer, 'db_manager'):
syncer.db_manager.close()
2025-12-02 22:05:54 +08:00
logger.info("同步服务停止")