iis服务器助手广告
返回顶部
首页 > 资讯 > 后端开发 > Python >线上dubbo线程池耗尽CyclicBarrier线程屏障异常解决记录
  • 545
分享到

线上dubbo线程池耗尽CyclicBarrier线程屏障异常解决记录

2024-04-02 19:04:59 545人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录事件背景问题定位解决问题文末结语 事件背景 系统相关使用人员反馈系统故障,日志显示从ams系统服务提示dubbo处理线程不足,具体异常信息如下: 问题定位 从上图可知,dubb

事件背景

系统相关使用人员反馈系统故障,日志显示从ams系统服务提示dubbo处理线程不足,具体异常信息如下:

问题定位

从上图可知,dubbo的处理线程池满了,默认200个线程,活动线程也是200个。这个现象非常不正常,我们的应用并发还没有到这个程度能同时占用200个线程处理请求。然后去读了下dubbo源码,发现dubbo也认为这种情况不正常,然后帮我们记录了应用的线程堆栈信息,这个非常赞。代码如下:

上面这段代码,在线程池不够用时,会每隔十分钟输出一份dump文件到用户目录,如:

在dump文件中,我们找到了耗尽DubboServerHandler线程池最后一个线程

通过分析得知:是我们应用程序有段代码导致的问题,在特定条件下会触发线程死,代码如下

代码中定义了一个线程屏障CyclicBarrier,同行数(调用await的线程数)是11,用来处理十个线程的运算,然后都计算完后拿到处理结果。本身代码没有什么问题,在没有并发的情况下,不会触发问题。但是注意中间那个箭头,执行线程的线程池是固定大小20的线程池,故当同时并发数多于2个的时候线程池的线程会不够用,导致线程等待,然后CyclicBarrier的main线程也会等待其他线程中的await。这就造成了相互等待,下一个请求过来还是继续等待,也就是死锁了。至此所有问题都以清晰明朗了。

解决问题

方案一:改CyclicBarrier为CountDownLatch,这个两个并发工具都是jdk1.5推出为了简化并发编程,CyclicBarrier的await会占用线程池中的线程不释放,导致线程不足,而CountDownLatch的count不会

方案二:改线程池类型为CachedThreadPool,不会应为线程池线程不够用,导致相互等待

文末结语

java并发包提供了丰富的api来简化多线程模型的开发,但是在针对多线程模型业务开发时,我们还需要多留心下多线程带来的坑。总之多核时代推荐大家多使用多线程开发,同时,也要对使用的工具有更多的了解

以上就是线上dubbo线程池耗尽CyclicBarrier线程屏障异常的详细内容,更多关于dubbo线程池耗尽CyclicBarrier线程屏障的资料请关注编程网其它相关文章!

--结束END--

本文标题: 线上dubbo线程池耗尽CyclicBarrier线程屏障异常解决记录

本文链接: https://www.lsjlt.com/news/140894.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 线上dubbo线程池耗尽CyclicBarrier线程屏障异常解决记录
    目录事件背景问题定位解决问题文末结语 事件背景 系统相关使用人员反馈系统故障,日志显示从ams系统服务提示dubbo处理线程不足,具体异常信息如下: 问题定位 从上图可知,dubb...
    99+
    2024-04-02
  • java线程池状态异常怎么解决
    当Java线程池出现状态异常时,可以尝试以下解决方法: 检查线程池是否关闭:使用`isShutdown()`方法检查线程池是否已...
    99+
    2023-10-25
    java
  • j2Cache线上异常排查问题解决记录分析
    目录问题背景问题分析假设问题小心求证问题重现问题解决问题后记-下面才是真正的原因重新假设最终解决问题背景 开发反馈,线上有个服务在运行一段时间后,就会抛异常导致redis缓存不可用。...
    99+
    2024-04-02
  • java主线程捕获子线程异常如何解决
    Java主线程可以通过以下几种方式捕获子线程的异常: 使用try-catch语句块:在子线程的run()方法中,可以使用try-c...
    99+
    2023-10-27
    java
  • 阿里Druid数据连接池引发的线上异常解决
    目录前言过程一:定位工作流过程二:定位JPA的OpenEntityManagerInViewInterceptor过程三:定位Druid,真正的罪魁祸首后记: 前言 事件起因:项目使...
    99+
    2024-04-02
  • WebWorker线程解决方案electron踩坑记录
    目录初始化项目编写入口文件和 electron 插件websocketwebsocket 服务连接 websocket 服务发送心跳取消心跳重新连接其它优化Worker初始化项目 e...
    99+
    2022-11-13
    Web Worker线程electron Web Worker
  • python线程捕获不到异常如何解决
    Python线程捕获不到异常的原因是因为线程中的异常默认是不会被抛出到主线程的。 解决这个问题,可以使用try/except语句在线...
    99+
    2023-10-27
    python
  • Java子线程任务异常和主线程事务回滚问题怎么解决
    这篇文章主要介绍了Java子线程任务异常和主线程事务回滚问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java子线程任务异常和主线程事务回滚问题怎么解决文章都会有所收获,下面我们一起来看看吧。一、提...
    99+
    2023-06-30
  • Java 详解循环屏障CyclicBarrier如何实现多线程分段等待执行完成
    前言 工作中是否有这样的场景,多个线程任务,如果所有线程完成到某个阶段,你希望知道所有线程均完成该阶段。当然你使用线程计数可以实现,只是不够优雅。 所以我即:Java 多线程等待优雅...
    99+
    2024-04-02
  • 阿里云服务器线程池故障原因分析及解决方案
    近年来,随着云计算技术的不断发展,越来越多的企业和个人选择使用阿里云服务器。然而,近日阿里云服务器线程池故障事件引起了广泛的关注。本文将详细分析阿里云服务器线程池故障的原因,并提供解决方案。 一、阿里云服务器线程池故障的原因分析线程池超负荷...
    99+
    2023-10-29
    阿里 线程 故障
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作