Executor异步执行数据库查询

项目需要,数据库串行查询导致接口调用超时,使用多线程和反射改为异步查询。

方式一:建议通用的查询参数配置的线程,再用反射调用

利用反射机制创建查询数据库的线程类(此处为无参数的反射):

public class SelectTaskNoArgsCallable<T> implements Callable {
    private Object object;
    private Object[] args;
    private String methodName;

    public SelectTaskNoArgsCallable(Object object, String methodName, Object[] args) {
        this.object = object;
        this.args = args;
        this.methodName = methodName;
    }

    @Override
    public T call() throws Exception {
        Method method = object.getClass().getMethod(methodName);   //此处应用反射机制,根据实际方法参数设置的
        return (T) method.invoke(object, args);
    }

}

Service层:

import java.util.*;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class TestService{
    @Autiwired
    private CardingAssetsDataResultMapper cardingAssetsDataResultMapper;
    public List<Object> multipleQueriesTest throws ExecutionException, InterruptedException{
        // 三个线程的线程池,核心线程=最大线程,没有临时线程,阻塞队列无界
        ExecutorService executorService = Executors.newFixedThreadPool(3);
        // 开启线程执行
        // 注意,此处Future对象接收线程执行结果不会阻塞,只有future.get()时候才会阻塞(直到线程执行完返回结果)
        Future future1 = executorService.submit(new SelectTaskNoArgsCallable<>(cardingAssetsDataResultMapper, "getSensitiveTypeIdAndColumnCountInfo", new Object[]{}));
        Future future2 = executorService.submit(new SelectTaskNoArgsCallable<>(cardingAssetsDataResultMapper, "getSensitiveTypeIdAndTableCountInfo", new Object[]{}));
        Future future3 = executorService.submit(new SelectTaskNoArgsCallable<>(cardingAssetsDataResultMapper, "getSensitiveTypeIdAndSchemaCountInfo", new Object[]{}));
        Object result1=future1.get();//此处可强转
        Object result2=future2.get();
        Object result3=future3.get();
        List<Object> results = new ArrayList<>();
        results.add(result1);
        results.add(result2);
        results.add(result3);
        executorService.shutdown();//关闭线程池
        return results;
    }
}

mapper方法自定义,此处不做记录。

方式二:java.util.concurrent.CompletableFuture使用,更简单;

CompletableFuture<Integer> integerCompletableFuture = CompletableFuture.supplyAsync(
() -> nmgModelConfigurationMapper.getListCount(NmgEventSourceVO.builder().excludeModelRuleIds(excludeModelRuleIdLists.stream().map(Integer::valueOf).collect(Collectors.toList())).tagStatus(0).build())
);
try {
    Integer integer = integerCompletableFuture.get();
} catch (InterruptedException | ExecutionException e) {
    e.printStackTrace();
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值