博客
关于我
四种线程池拒绝策略
阅读量:203 次
发布时间:2019-02-28

本文共 1846 字,大约阅读时间需要 6 分钟。

线程池拒绝策略深入解析

在线程池管理中,拒绝策略是处理任务过载情况的重要机制。线程池在任务数量超过其容量时,会根据配置的策略对超出任务进行处理。以下将详细介绍线程池的四种拒绝策略及其适用场景。

1. AbortPolicy(默认策略)

描述:

AbortPolicy是线程池默认的拒绝策略。当线程池的任务缓存队列已满且线程数达到最大值时,新任务将被丢弃,并抛出RejectedExecutionException异常。

特点:

  • 丢弃任务。
  • 抛出异常。
  • 适用于关键业务场景,能及时反馈系统过载状态。

示例:

在一个高并发的数据处理系统中,使用AbortPolicy可以确保系统在任务过载时快速失败,并通过异常提示管理员进行干预。


2. DiscardPolicy

描述:

DiscardPolicy策略会将任务静默丢弃,不抛出异常。如果线程池已满,后续任务将被丢弃,不会有任何异常信息。

特点:

  • 不抛出异常。
  • 静默丢弃任务。
  • 适用于对异常不敏感的业务场景。

示例:

在博客网站的阅读量统计功能中,采用DiscardPolicy可以避免服务器过载,并不影响用户体验。


3. DiscardOldestPolicy

描述:

DiscardOldestPolicy策略会丢弃队列中最前面的任务,然后重新提交被拒绝的任务(除非线程池已关闭)。

特点:

  • 喜新厌旧,优先丢弃旧任务。
  • 可能导致部分任务重复提交。
  • 适用于允许任务重复提交的场景。

示例:

在某些实时监控系统中,DiscardOldestPolicy可以避免长时间任务积累,同时确保关键任务能及时执行。


4. CallerRunsPolicy

描述:

CallerRunsPolicy策略会将被拒绝的任务直接由提交线程执行,避免线程池负载过重。

特点:

  • 任务由提交线程直接处理。
  • 不会增加线程池的负载。
  • 适用于对任务延迟敏感的场景。

示例:

在网络爬虫或实时数据处理任务中,CallerRunsPolicy可以防止任务被拖延,确保数据处理的及时性。


线程池默认拒绝策略

在线程池初始化时,默认的拒绝策略是AbortPolicy。通过查看ThreadPoolExecutor类的源码,可以看到:

private static final RejectedExecutionHandler defaultHandler = new AbortPolicy();

这表明,默认情况下,线程池会采用丢弃任务并抛出异常的策略。通过自定义线程池配置,我们可以根据需求更改拒绝策略。


自定义线程池拒绝策略

在实际开发中,可以通过线程池的构造方法或 setter方法来配置拒绝策略。例如,在Spring框架中,可以使用ThreadPoolTaskExecutor:

@Configurationpublic class TaskExecutorConfig implements AsyncConfigurer {    @Override    public Executor getAsyncExecutor() {        ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();        taskExecutor.setCorePoolSize(5);        taskExecutor.setMaxPoolSize(5);        taskExecutor.setQueueCapacity(1000);        taskExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.DiscardPolicy());        taskExecutor.initialize();        return taskExecutor;    }}

拒绝策略的选择要点

  • AbortPolicy:推荐用于关键业务,确保系统状态可控。
  • DiscardPolicy:适用于对异常不敏感的场景,静默处理任务过载。
  • DiscardOldestPolicy:适用于允许任务重复提交的场景,避免长时间任务积累。
  • CallerRunsPolicy:用于对任务延迟敏感的场景,确保任务能及时执行。
  • 在实际应用中,应根据业务需求和系统架构来选择最合适的拒绝策略,确保线程池的高效运行和系统的稳定性。

    转载地址:http://ymhs.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现kth order statistick阶统计量算法(附完整源码)
    查看>>
    Objective-C实现Lempel-Ziv压缩算法(附完整源码)
    查看>>
    Objective-C实现logistic regression逻辑回归算法(附完整源码)
    查看>>
    Objective-C实现LongestIncreasingSubsequence最长递增子序列算法(附完整源码)
    查看>>
    Objective-C实现Lower-Upper Decomposition上下分解算法(附完整源码)
    查看>>
    Objective-C实现lowest common ancestor最低共同祖先算法(附完整源码)
    查看>>
    Objective-C实现LRU 缓存算法(附完整源码)
    查看>>
    Objective-C实现LRU缓存(附完整源码)
    查看>>
    Objective-C实现lstm prediction预测算法(附完整源码)
    查看>>
    Objective-C实现lucas数列算法(附完整源码)
    查看>>
    Objective-C实现Luhn (Mod 10)Algorithm算法(附完整源码)
    查看>>
    Objective-C实现LZW编码(附完整源码)
    查看>>
    Objective-C实现MAC桌面暗水印(附完整源码)
    查看>>
    Objective-C实现markov chain马尔可夫链算法(附完整源码)
    查看>>
    Objective-C实现MATLAB中Filter函数功能(附完整源码)
    查看>>
    Objective-C实现matrix exponentiation矩阵求幂算法(附完整源码)
    查看>>
    Objective-C实现MatrixMultiplication矩阵乘法算法 (附完整源码)
    查看>>
    Objective-C实现max non adjacent sum最大非相邻和算法(附完整源码)
    查看>>
    Objective-C实现max subarray sum最大子数组和算法(附完整源码)
    查看>>
    Objective-C实现MaximumSubarray最大子阵列(Brute Force蛮力解决方案)算法(附完整源码)
    查看>>