1
zj
2025-11-04 cb3124ebcaf7feb37cd59a96b8377eaf7b7f906b
src/main/java/com/nq/utils/task/stock/StockTask.java
@@ -14,6 +14,7 @@
import com.nq.service.IMandatoryLiquidationService;
import com.nq.service.IStockService;
import com.nq.service.IUserPositionService;
import com.nq.service.UserPendingorderService;
import com.nq.utils.http.HttpClientRequest;
import com.nq.utils.redis.RedisKeyUtil;
import org.slf4j.Logger;
@@ -25,6 +26,7 @@
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
@@ -38,6 +40,8 @@
    @Autowired
    IUserPositionService userPositionService;
    @Autowired
    UserPendingorderService userPendingorderService;
    @Autowired
    UserPositionMapper userPositionMapper;
@@ -52,27 +56,34 @@
    private static final Logger log = LoggerFactory.getLogger(StockTask.class);
    boolean syncINStockData = true;
    private final AtomicBoolean syncINStockData = new AtomicBoolean(false);
    private final Lock syncINStockDataLock = new ReentrantLock();
    /**
     * 同步系统所需要的股票
     */
    @Scheduled(cron = "0 0 0/2  * * ?")
    @Scheduled(cron = "0 0/1 * * * ?")
    public void syncINStockData() {
        if (syncINStockData)
            syncINStockData = false;
        else return;
        if (syncINStockData.get()) { // 判断任务是否在处理中
            return;
        }
        if (syncINStockDataLock.tryLock()) {
            try {
                loadAllStock(EStockType.IN);
//        loadAllStock(EStockType.HK);
                syncINStockData.set(true); // 设置处理中标识为true
                loadAllStock(EStockType.US);
            } finally {
                syncINStockDataLock.unlock();
                syncINStockData = true;
                syncINStockData.set(false); // 设置处理中标识为false
            }
        }
    }
//    @Scheduled(cron = "0 0/1 * * * ?")
    @Scheduled(cron = "0 30 21 * * ?")
    public void delUserPendingorder() {
        userPendingorderService.delUserPendingorderTask();
    }
@@ -170,18 +181,19 @@
        }
    }
    boolean stockConstraint = true;
    private final AtomicBoolean stockConstraint = new AtomicBoolean(false);
    /**
     * 强制平仓
     */
    @Scheduled(cron = "0/1 * * * * ?")
//    @Scheduled(cron = "0/1 * * * * ?")
    public void stockConstraint() {
        if (stockConstraint)
            stockConstraint = false;
        else return;
        if (stockConstraint.get()) { // 判断任务是否在处理中
            return;
        }
        if (stockConstraintLock.tryLock()) {
            try {
                stockConstraint.set(true); // 设置处理中标识为true
                List<UserPosition> userPositions = userPositionMapper.selectList(new LambdaQueryWrapper<UserPosition>().isNull(UserPosition::getSellOrderId));
                if (CollectionUtils.isNotEmpty(userPositions)) {
                    userPositionService.stockConstraint(userPositions);
@@ -191,7 +203,7 @@
                log.error("强制平仓任务错误:" + e.getMessage());
            } finally {
                stockConstraintLock.unlock();
                stockConstraint = true;
                stockConstraint.set(false); // 设置处理中标识为false
            }
        } else {
            log.info("强制平仓任务--------->上次任务还未执行完成,本次任务忽略");