From ac33f4fad8d6e2df70680827f391ed555631e05f Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 15 Dec 2025 20:35:16 +0800
Subject: [PATCH] feat(okx): 调整开仓张数配置及网格间距
---
src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java | 101 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 101 insertions(+), 0 deletions(-)
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java
new file mode 100644
index 0000000..d8981d0
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java
@@ -0,0 +1,101 @@
+package com.xcong.excoin.modules.okxNewPrice;
+
+import com.xcong.excoin.modules.okxNewPrice.celue.CaoZuoService;
+import com.xcong.excoin.modules.okxNewPrice.okxWs.enums.ExchangeInfoEnum;
+import com.xcong.excoin.modules.okxNewPrice.wangge.WangGeService;
+import com.xcong.excoin.utils.RedisUtils;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
+import org.springframework.stereotype.Component;
+
+import javax.annotation.PostConstruct;
+import javax.annotation.PreDestroy;
+import java.util.*;
+import java.util.concurrent.ConcurrentHashMap;
+
+/**
+ * 管理多个OKX WebSocket客户端实例,每个实例对应一个账号
+ */
+@Slf4j
+@Component
+@ConditionalOnProperty(prefix = "app", name = "quant", havingValue = "true")
+public class OkxWebSocketClientManager {
+ @Autowired
+ private WangGeService wangGeService;
+ @Autowired
+ private CaoZuoService caoZuoService;
+ @Autowired
+ private RedisUtils redisUtils;
+
+ // 存储所有WebSocket客户端实例,key为账号类型名称
+ private final Map<String, OkxQuantWebSocketClient> clientMap = new ConcurrentHashMap<>();
+
+ /**
+ * 初始化方法,在Spring Bean构造完成后执行
+ * 创建并初始化所有账号的WebSocket客户端实例
+ */
+ @PostConstruct
+ public void init() {
+ log.info("开始初始化OkxWebSocketClientManager");
+
+ // 获取所有ExchangeInfoEnum枚举值
+ ExchangeInfoEnum[] accounts = ExchangeInfoEnum.values();
+
+ // 为每个账号创建一个WebSocket客户端实例
+ for (ExchangeInfoEnum account : accounts) {
+ try {
+ OkxQuantWebSocketClient client = new OkxQuantWebSocketClient(account, wangGeService, caoZuoService, redisUtils);
+ clientMap.put(account.name(), client);
+ client.init();
+ log.info("已初始化账号 {} 的WebSocket客户端", account.name());
+ } catch (Exception e) {
+ log.error("初始化账号 {} 的WebSocket客户端失败", account.name(), e);
+ }
+ }
+
+ log.info("OkxWebSocketClientManager初始化完成");
+ }
+
+ /**
+ * 销毁方法,在Spring Bean销毁前执行
+ * 关闭所有WebSocket客户端连接和相关资源
+ */
+ @PreDestroy
+ public void destroy() {
+ log.info("开始销毁OkxWebSocketClientManager");
+
+ // 关闭所有客户端实例
+ for (Map.Entry<String, OkxQuantWebSocketClient> entry : clientMap.entrySet()) {
+ try {
+ OkxQuantWebSocketClient client = entry.getValue();
+ client.destroy();
+ log.info("已销毁账号 {} 的WebSocket客户端", entry.getKey());
+ } catch (Exception e) {
+ log.error("销毁账号 {} 的WebSocket客户端失败", entry.getKey(), e);
+ }
+ }
+
+ // 清空客户端映射
+ clientMap.clear();
+
+ log.info("OkxWebSocketClientManager销毁完成");
+ }
+
+ /**
+ * 获取指定账号的WebSocket客户端实例
+ * @param accountName 账号类型名称
+ * @return WebSocket客户端实例
+ */
+ public OkxQuantWebSocketClient getClient(String accountName) {
+ return clientMap.get(accountName);
+ }
+
+ /**
+ * 获取所有WebSocket客户端实例
+ * @return 所有客户端实例的集合
+ */
+ public Collection<OkxQuantWebSocketClient> getAllClients() {
+ return clientMap.values();
+ }
+}
\ No newline at end of file
--
Gitblit v1.9.1