package org.example.geteclient.WsBean; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import lombok.extern.slf4j.Slf4j; import org.example.geteclient.GeteClientApplication; import org.example.geteclient.pojo.Currency; import org.example.geteclient.server.impl.CurrencySerivceImpl; import org.example.geteclient.wsClinet.GateClient; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.SpringApplication; import org.springframework.context.ConfigurableApplicationContext; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import org.springframework.util.CollectionUtils; import java.util.List; /** * @ClassDescription: 客户端请求类 * @JdkVersion: 1.8 * @Created: 2023/8/31 16:13 */ @Slf4j @Configuration public class GateWsBean { @Autowired private CurrencySerivceImpl currencyService; @Autowired @Qualifier("threadPoolTaskExecutor") private ThreadPoolTaskExecutor threadPoolTaskExecutor; @Bean public void gateWebsocketRunClientMap() { List mexc = currencyService.list(new LambdaQueryWrapper().eq(Currency::getSource, "gate").eq(Currency::getQuoteAsset,"USDT")); if (!CollectionUtils.isEmpty(mexc)) { int batchSize = 100; // 每个线程处理的数据量 int totalSize = mexc.size(); int threadCount = (int) Math.ceil((double) totalSize / batchSize); // 计算需要的线程数 for (int i = 0; i < threadCount; i++) { int fromIndex = i * batchSize; int toIndex = Math.min(fromIndex + batchSize, totalSize); List sublist = mexc.subList(fromIndex, toIndex); // 使用自定义线程池提交任务 threadPoolTaskExecutor.execute(() -> { new GateClient(sublist).start(); }); } } } }