spring boot + dubbo 优雅关闭_微服务框架篇——学习dubbo如何优雅关闭线程池,超实用!...

基本方法学习

线程池是我们经常使用的工具,也是面试必问的知识点,那么如何优雅的关闭线程池那?

线程池相信大家都使用过,但是使用完成之后如何关闭线程池大家真的未必真的会使用。有人可能会说调用shutdown或者shutdownNow就可以了,真的有那么简单吗?如果你关闭线程池的姿势不正确,最严重的情况会导致线程一直存在系统中。

  • shutDown:通知线程池启动有序关闭,执行线程池之前已经提交的任务,但是不再接受新的任务。调用shutDown后再提交任务将会抛出RejectedExecutionException异常。
  • shutDownNow:尝试立即停止所有已经提交的任务,并会返回正在等待执行(未执行)的任务列表。shutDownNow通过向线程池中的线程发送一个中断请求而中止线程,如果线程池中运行了会抛出InterruptedException的程序,将会抛出一个InterruptedException。如果这个线程不能响应中断那么可能永远无法被终止。
  • isTerminated:所有的任务都被关闭返回true,否则返回false。只有调用了shutDown或者shutDownNow,isTerminated才可能为true。
  • awaitTermination(long timeout, TimeUnit unit) throws InterruptedException:阻塞当前线程直到 所有任务执行完毕 或者超时 或者当前线程被中断 如果所有任务都关闭,则返回true,否则返回false。

优雅关闭线程池的正确姿势

  • step1:执行shutdown方法,等待所有任务执行完毕并拒绝新任务的提交。
  • step2:执行awaitTermination(long timeout,TimeUnit unit),指定超时时间,判断是是否已经关闭所有任务,防止线程永远无法关闭。
  • step3:如果step2返回fasle,或者被中断。调用shutDownNow方法立即关闭线程池所有任务。

dubbo关闭线程池工具类学习

f277aa47b5d097ffd60796033d14c0bb.png

原文链接:https://juejin.im/post/5e9ec57df265da47c9171456

喜欢的老哥可以帮忙转发关注一下!

推荐阅读:美团面试官:高并发、任务执行时间短的业务怎样使用线程池?

全网精选架构技术合集:Spring全家桶+分布式+MySQL+Nginx+Dubbo

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值