From cdfc565cf68600e4690f6668b9a08889a81ca6af Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 11 Dec 2025 20:48:56 +0800
Subject: [PATCH] feat(okx): 增强OKX WebSocket连接稳定性
---
src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java | 20 +++++++++++++++-----
1 files changed, 15 insertions(+), 5 deletions(-)
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java
index 22e46bc..6d32560 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java
@@ -71,6 +71,11 @@
* @param redisUtils Redis 工具类实例,用于存储账户相关信息
*/
public static void handleEvent(JSONObject response, RedisUtils redisUtils) {
+
+
+ String state = (String) redisUtils.get(InstrumentsWs.INSTRUMENTSWS_CHANNEL + ":" + CoinEnums.HE_YUE.getCode() + ":state");
+
+ log.info("开始执行AccountWs......{}",state);
try {
JSONArray dataArray = response.getJSONArray(DATA_KEY);
if (dataArray == null || dataArray.isEmpty()) {
@@ -83,6 +88,7 @@
JSONObject accountData = dataArray.getJSONObject(i);
JSONArray detailsArray = accountData.getJSONArray(DETAILS_KEY);
if (detailsArray == null || detailsArray.isEmpty()) {
+ log.warn("账户频道{}数据为空",CoinEnums.USDT.getCode());
continue;
}
@@ -95,7 +101,7 @@
String eq = detail.getString(EQ_KEY);
if (StrUtil.isBlank(ccy) || StrUtil.isBlank(availBalStr) || StrUtil.isBlank(cashBalStr)) {
- log.warn("账户详情缺失必要字段,跳过处理");
+ log.warn("账户频道缺失必要字段,跳过处理");
continue;
}
@@ -103,15 +109,19 @@
BigDecimal cashBal = parseBigDecimalSafe(cashBalStr);
if (availBal == null || cashBal == null || cashBal.compareTo(BigDecimal.ZERO) == 0) {
- log.warn("无效的账户余额数据,跳过处理");
+ log.warn("账户频道无效的账户余额数据,跳过处理");
continue;
}
// 可用余额 / 现金余额 比例判断是否允许开仓
BigDecimal divide = availBal.divide(cashBal, 4, RoundingMode.DOWN);
-
- String state = (String) redisUtils.get(InstrumentsWs.INSTRUMENTSWS_CHANNEL + ":" + CoinEnums.HE_YUE.getCode() + ":state");
- if (!OrderParamEnums.STATE_3.getValue().equals(state)){
+ if (OrderParamEnums.STATE_4.getValue().equals(state)){
+ log.info(OrderParamEnums.STATE_4.getName());
+ state = OrderParamEnums.STATE_4.getValue();
+ }else if(OrderParamEnums.STATE_3.getValue().equals(state)){
+ log.info(OrderParamEnums.STATE_3.getName());
+ state = OrderParamEnums.STATE_3.getValue();
+ }else{
if (divide.compareTo(KANG_CANG_THRESHOLD) > 0) {
log.info(OrderParamEnums.STATE_1.getName());
state = OrderParamEnums.STATE_1.getValue();
--
Gitblit v1.9.1