当前位置: 首页 > article >正文

创建 RpcThreadPoolUtil 工具类

为了将线程池封装成一个通用的工具类,以便在所有RPC接口调用时复用,你可以创建一个工具类 RpcThreadPoolUtil。这个工具类将负责创建和管理线程池,并提供一个方法来异步执行RPC调用。
  1. 创建 RpcThreadPoolUtil 工具类
import java.util.concurrent.*;

public class RpcThreadPoolUtil {
    private static final int CORE_POOL_SIZE = 10; // 核心线程数
    private static final int MAXIMUM_POOL_SIZE = 20; // 最大线程数
    private static final long KEEP_ALIVE_TIME = 60L; // 线程空闲时间
    private static final TimeUnit TIME_UNIT = TimeUnit.SECONDS; // 时间单位
    private static final BlockingQueue<Runnable> WORK_QUEUE = new LinkedBlockingQueue<>(); // 工作队列

    private static final ExecutorService EXECUTOR;

    static {
        // 初始化线程池
        EXECUTOR = new ThreadPoolExecutor(
                CORE_POOL_SIZE,
                MAXIMUM_POOL_SIZE,
                KEEP_ALIVE_TIME,
                TIME_UNIT,
                WORK_QUEUE,
                new ThreadFactory() {
                    @Override
                    public Thread newThread(Runnable r) {
                        Thread t = new Thread(r);
                        t.setName("Rpc-Thread-Pool-Worker");
                        return t;
                    }
                },
                new ThreadPoolExecutor.AbortPolicy() // 拒绝策略
        );
    }

    /**
     * 异步执行RPC调用
     *
     * @param callable RPC调用的Callable任务
     * @param <T>      返回结果的类型
     * @return CompletableFuture
     */
    public static <T> CompletableFuture<T> executeAsync(Callable<T> callable) {
        return CompletableFuture.supplyAsync(() -> {
            try {
                return callable.call();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        }, EXECUTOR);
    }

    /**
     * 关闭线程池
     */
    public static void shutdown() {
        EXECUTOR.shutdown();
    }

    /**
     * 立即关闭线程池
     */
    public static void shutdownNow() {
        EXECUTOR.shutdownNow();
    }
}
  1. 使用 RpcThreadPoolUtil 进行RPC调用
    在你的业务逻辑中,可以使用 RpcThreadPoolUtil 来异步执行RPC调用。例如:
import java.util.LinkedHashMap;
import java.util.Objects;
import com.fasterxml.jackson.databind.ObjectMapper;

public class YourClass {
    private final ObjectMapper objectMapper;

    public YourClass() {
        this.objectMapper = new ObjectMapper();  // 初始化 ObjectMapper
    }

    public void processVerification(OrderSignOffInput signOffInput, String hospitalSOID, VerifyOutput verifyOutput) {
        // 使用 RpcThreadPoolUtil 异步调用 getFreeClass 方法
        RpcThreadPoolUtil.executeAsync(() -> initializeVerifyService().getFreeClass(
                signOffInput.getOrSignInput(), 
                hospitalSOID, 
                signOffInput.getDoctorId()
        )).thenAccept(agreementMedicineVerifyOutputDTO -> {
            if (agreementMedicineVerifyOutputDTO != null) {
                verifyOutput.setVerifyActionId(13L);
                verifyOutput.getSignVerifyResultList().add(this.createSignCommonVerifuResult(
                        13L, 
                        objectMapper.convertValue(agreementMedicineVerifyOutputDTO, LinkedHashMap.class)
                ));
            }
        }).exceptionally(ex -> {
            // 处理异常
            ex.printStackTrace();
            return null;
        });
    }


    // 在适当的地方调用 shutdown 方法以关闭线程池
    public void shutdown() {
        RpcThreadPoolUtil.shutdown();
    }
}

http://www.kler.cn/news/367060.html

相关文章:

  • 15分钟学 Go 第 22 天:包的使用
  • 二进制方式部署k8s集群
  • 【Linux】线程池详解及其基本架构与单例模式实现
  • 【pytest学习】pytest.main()
  • centeros7 编译ffmpeg
  • 【2024|滑坡数据集论文解读1】CAS滑坡数据集:用于深度学习滑坡检测的大规模多传感器数据集
  • 在 Kakarot ZkEVM 上使用 Starknet Scaffold 构建应用
  • 如何在轻量云服务器上搭建一个基本的开发环境
  • PostgreSQL 约束
  • SSL VPN调试思路及配置指南
  • 三国杀钓鱼自动化
  • 【人工智能-初级】第21章 线性代数与 AI:理解矩阵乘法和特征向量
  • java核心技术点都有哪些
  • C# Windows桌面应用打包指南
  • 算法的学习笔记—和为 S 的两个数字(牛客JZ57)
  • Linux基础命令:轻松掌握终端操作
  • 十一、数据库配置
  • CI/CD 流水线系统-开源框架Tekton
  • windows 上面交叉编译 适合arm架构上的linux内核系统的qt 版本,源码编译
  • MYSQL-查看创建的用户语法(十二)
  • C++音视频02:环境搭建
  • 【rust实战】rust博客系统2_使用wrap启动rust项目服务
  • 基于DDPG算法的股票量化交易
  • 浮动+flex布局
  • Django项目实战-图书管理系统之项目搭建
  • c# windows 动态生成CheckBox控件