17.拒绝策略

本文详细介绍了Java中ThreadPoolExecutor的四种内置拒绝策略:AbortPolicy、CallerRunsPolicy、DiscardOldestPolicy及DiscardPolicy,并提供了每种策略的行为特征及适用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       ThreadPoolExecutor的最后一个参数指定了拒绝策略,也就是当线程池中的线程已经使用完了,无法为新的任务服务,同时等待队列中也已经排满了,再也无法塞下新任务了。拒绝策略就是用来处理这个情况的。

       JDK内置了四种拒绝策略:

       1.AbortPolicy:直接抛出异常,阻止系统正常工作;

       2.CallerRunsPolicy:只要线程池未关闭,直接在调用者线程中运行当前被等待队列拒绝加入的任务。提交任务的线程的性能会急剧下降。

       3.DiscardOledestPolicy:丢弃最老的一个请求,也就是即将被执行的一个·任务,并尝试再次提交当前任务(不是最老的请求)。

       4.DiscardPolicy:丢弃无法处理的任务,不做任何处理。

       以上四种策略均是通过实现RejectedExecutionHandler接口来实现的。我们可以通过实现这个接口来自定义策略。

//r为请求执行的任务
//executor为当前的线程池
public interface RejectedExecutionHandler {
    void rejectedExecution(Runnable r,ThreadPoolExecutor executor);
}
"connect to host 172.17.22.33 port 48022: Connection refused" 这个错误信息表明你在尝试通过网络连接到特定IP地址(这里是`172.17.22.33`)和端口(`48022`)时遇到了障碍,对方服务器明确拒绝了这个连接请求。 **原因解释**: 1. **防火墙设置**:目标主机可能有防火墙设置阻止从你的来源IP地址和端口发起的连接请求。 2. **服务未运行**:即使防火墙允许该连接,也可能是因为在目标端口上未启动相关的网络服务,比如用于远程登录、数据库访问或其他需要端口开放的服务。 3. **权限问题**:你可能没有足够的权限去连接到那个特定的IP和端口号。这通常适用于安全敏感的应用场景。 4. **网络限制**:可能是由于网络设备配置导致的阻塞,例如路由器规则或ISP策略限制了某些类型的流量。 5. **协议不匹配**:在尝试连接时使用的协议可能与实际监听端口的服务不兼容。 **解决方案**: 1. **检查防火墙设置**:确认目标主机的防火墙是否允许来自你的IP地址的连接,并且是否有针对特定端口的规则。 2. **验证服务状态**:确保目标主机上对应于你想连接的端口的服务正在运行并监听该端口。 3. **测试其他连接**:尝试使用ping命令等基本网络测试工具来验证目标主机的可达性和其网络状况。 4. **询问管理员**:如果这是内部网络的问题,联系网络管理员查看是否存在特定的网络策略或设备配置问题。 5. **端口扫描**:使用端口扫描工具(如nmap)来检测目标主机上特定端口的状态,了解是否真的有人接收连接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值