记一次线程池资源耗尽问题排查

问题描述

这边有一个项目基于开源项目ThingsBoard,Github链接是https://github.com/thingsboard/thingsboard。具体是这样的,在上线后,开始系统各个模块正常运作,但是从规则引擎界面配置调用外部接口采集数据后,经过3~4小时,包括登录接口在内的系统前端交互接口均开始出现接口503。且重启后问题复现,无法自行恢复。规则引擎侧采集的设备信息也同步停止新增。

问题分析

思路是这样的。若系统不调用数据采集接口进行设备信息采集,则线上无问题。数据采集接口如何影响前端UI界面的正常请求?没错了,答案就是:资源耦合!
顺着这个思路排查到了如下代码:
在这里插入图片描述
可以看到ThingsBoard里这个数据库请求都是包了一层异步。然后这边项目里数据库有mysql和tdengine(一款国内研发的时序数据库:https://www.taosdata.com/)。最终定位到了耦合的资源,如下图:
在这里插入图片描述
可以看到前端用户请求 -> 线程池(ForkJoinPool) -> 连接池(HikariPool) -> mysql。规则引擎 -> 线程池(ForkJoinPool) -> 连接池(HikariPool) -> tdengine。两者使用了同一个线程池做异步,线程池设置为16。mysql连接池大小16,tdengine连接池大小20且未设置超时。这个公用的线程池资源耗尽导致前端请求阻塞超时!那么接下来又来了一个问题:td请求阻塞还是mysql请求阻塞?

jstack日志分析

在这里插入图片描述
从jstack线程栈日志看出,ForkjoinFool里阻塞的task都是tdengine的!

jvm dump分析

在这里插入图片描述
从JVM dump信息中查看程序运行时正在执行的数据库SQL请求情况。通过源码追踪可知,所有数据库SQL请求均被封装为HirariProxyPreparedStatement,而系统异常状态下,共计16个正在运行中的HirariProxyPreparedStatement同时存在,与JpaExecutorService线程上限一致,且所有SQL均是TdEngine的插入操作。至此真相大白!

结论

总结下来,这其实是一个比较典型的线程池资源耗尽问题。针对线程池资源耗尽问题,最好的处理方式是让Mysql和TdEngine使用单独线程池,达到资源解耦目的,但是该方案需要修改代码,上线审批流程较长。因此,作为临时方案,可修改配置文件,增加最大线程数,并同时设置TdEngine连接池超时时间,使得线程池资源在TdEngine请求都超时的最坏情况下依然能正常工作。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
关于 Java 线程池导致 MySQL 的 Bug,可能是由于线程池中的线程数量过多,导致 MySQL 连接池被耗尽,从而出现连接超时或者连接泄露的情况。这种情况下,可以通过优化线程池的配置,增加 MySQL 连接池的大小,或者使用连接池管理工具进行监控和管理,来避免这种情况的发生。 至于关于线程池问题,可以具体分为以下几个方面: 1. 线程池的大小:线程池的大小需要根据实际的业务场景来进行设置,如果线程池的大小过小,可能会导致任务无法及时处理,而过大则会占用过多的系统资源,影响系统的性能表现。 2. 线程池的类型:线程池的类型包括 FixedThreadPool、CachedThreadPool、ScheduledThreadPool 等,不同类型的线程池适用于不同的场景,需要根据实际的业务需求进行选择。 3. 线程池的拒绝策略:当线程池中的任务数量超过线程池的最大容量时,需要采取一定的拒绝策略,如 AbortPolicy、CallerRunsPolicy、DiscardOldestPolicy 等,需要根据业务场景和系统性能要求进行选择。 4. 线程池的生命周期管理:线程池的生命周期包括创建、启动、运行、停止等多个阶段,在使用线程池时需要对其进行合理的生命周期管理,以确保线程池的稳定运行和性能表现。 总之,线程池是一个非常重要的并发编程工具,需要在实践中不断学习和积累经验,以提高系统的性能和稳定性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值