xxl-job java.sql.SQLException: interrupt问题排查(二)

在解决完之前出现的xxl-job java.sql.SQLException: interrupt问题后(参见:xxl-job java.sql.SQLException: interrupt问题排查

线上运行的某一天突然又出现了同样的报错

java 复制代码
ConnectionManager [Thread-23069] getWriteConnection db:***,pattern: error, jdbcUrl: jdbc:mysql://***:3306/***?connectTimeout=3000&socketTimeout=180000&autoReconnect=true&zeroDateTimeBehavior=CONVERT_TO_NULL&characterEncoding=utf8 java.sql.SQLException: interrupt 	at com.alibaba.druid.pool.DruidDataSource.getConnectionInternal(DruidDataSource.java:1430) ~[druid-1.1.12.jar!/:1.1.12] 	at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:1272) ~[druid-1.1.12.jar!/:1.1.12] 	at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:5007) ~[druid-1.1.12.jar!/:1.1.12] 	at com.alibaba.druid.filter.FilterAdapter.dataSource_getConnection(FilterAdapter.java:2745) ~[druid-1.1.12.jar!/:1.1.12]

只不过这次报错是在另一个定时任务,这种肯定还是代码内部触发了线程中断,druid响应了这个中断,分析这个新的定时任务特点:

  • 没有设置超时时间(也就排除了可能是因为任务超时导致的触发中断)
  • 任务采用的路由策略是轮询,阻塞处理策略是覆盖之前调度
  • 任务每隔一分钟调度一次
  • 应用服务器有三台机器

观察报错,发现报错的是固定时间点的任务,这个时间点任务执行较长需要4分钟左右,最终查看日志发现

说明是由于下一次任务覆盖上一次任务,触发了任务的终止,触发了线程中断,代码位于

定位到问题解决方案有两种:

  1. 定时任务,业务代码异步执行(推荐)
  2. 调整定时任务的执行频率
相关推荐
sunnyday042615 小时前
深入理解Java日志框架:Logback与Log4j2配置对比分析
java·log4j·logback
superman超哥15 小时前
Rust HashSet与BTreeSet的实现细节:集合类型的底层逻辑
开发语言·后端·rust·编程语言·rust hashset·rust btreeset·集合类型
浩瀚地学15 小时前
【Java】异常
java·开发语言·经验分享·笔记·学习
张np15 小时前
java基础-LinkedHashMap
java·开发语言
gihigo199815 小时前
基于MATLAB的周期方波与扫频信号生成实现(支持参数动态调整)
开发语言·matlab
行者9615 小时前
Flutter适配OpenHarmony:国际化i18n实现中的常见陷阱与解决方案
开发语言·javascript·flutter·harmonyos·鸿蒙
csbysj202015 小时前
RSS 阅读器:全面解析与使用指南
开发语言
毕设源码-朱学姐15 小时前
【开题答辩全过程】以 高校图书馆管理系统为例,包含答辩的问题和答案
java
xie_pin_an16 小时前
C++ 从入门到进阶:核心知识与实战指南
java·c++·算法