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

本文共 1858 字,大约阅读时间需要 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:

@Configuration
public 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/

    你可能感兴趣的文章
    npm切换源淘宝源的两种方法
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm包管理深度探索:从基础到进阶全面教程!
    查看>>
    npm升级以及使用淘宝npm镜像
    查看>>
    npm发布包--所遇到的问题
    查看>>
    npm发布自己的组件UI包(详细步骤,图文并茂)
    查看>>
    npm和package.json那些不为常人所知的小秘密
    查看>>
    npm和yarn清理缓存命令
    查看>>
    npm和yarn的使用对比
    查看>>
    npm如何清空缓存并重新打包?
    查看>>
    npm学习(十一)之package-lock.json
    查看>>
    npm安装 出现 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! 解决方法
    查看>>
    npm安装crypto-js 如何安装crypto-js, python爬虫安装加解密插件 找不到模块crypto-js python报错解决丢失crypto-js模块
    查看>>
    npm安装教程
    查看>>
    npm报错Cannot find module ‘webpack‘ Require stack
    查看>>
    npm报错Failed at the node-sass@4.14.1 postinstall script
    查看>>
    npm报错fatal: Could not read from remote repository
    查看>>
    npm报错File to import not found or unreadable: @/assets/styles/global.scss.
    查看>>
    npm报错TypeError: this.getOptions is not a function
    查看>>
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>