MySQL数据库报“You are not owner of thread”错误的解决方法

背景

最近在做数据归档相关需求,最终方案采用存储过程进行归档,由应用服务去调度,在测试过程中出现以下错误,但是存储过程是正常执行成功

复制代码
### SQL: call proc_archive_table             (                 ?, ?,                 ?, ?,                 ?, ?,                 ?, ?             )
### Cause: java.sql.SQLException: You are not owner of thread 301928
; uncategorized SQLException; SQL state [HY000]; error code [1095]; You are not owner of thread 301928; nested exception is java.sql.SQLException: You are not owner of thread 301928
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:89)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
	at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:88)
Caused by: java.sql.SQLException: You are not owner of thread 301928
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129)
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
	at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122)
	at com.mysql.cj.jdbc.ClientPreparedStatement.executeInternal(ClientPreparedStatement.java:953)
	at com.mysql.cj.jdbc.ClientPreparedStatement.execute(ClientPreparedStatement.java:370)
	at com.mysql.cj.jdbc.CallableStatement.execute(CallableStatement.java:845)
	at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483)

找到异常关键词后有点不解随即开始百度:You are not owner of thread 301928

大多都是在说权限不足导致的

例:MySQL数据库报"You are not owner of thread"错误的解决方法

但再三检查该用户权限后都无济于事,最终给到了root用户来进行测试也不行。。。

最后在同事的帮助指引下进行抓包查看,贴下正常与异常报文

异常报文在 调度存储过程后 5s 左右发起了一个Login Request的报文,随即 发送了一个 Kill 请求,继而响应:You are not owner of thread 301928

以此为突破点,回想系统的配置参数:德鲁伊: query-timeout:5s,随即便调大了此参数重新进行测试, 缤果, 没问题了。。。百思不得其解

结语

因此归档任务执行会非常耗时,本着不影响系统的原则 在对应 select 标签上增加 timeout 参数进行单独控制此 存储过程的执行超时时间

相关推荐
tan180°6 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
DuelCode7 小时前
Windows VMWare Centos Docker部署Springboot 应用实现文件上传返回文件http链接
java·spring boot·mysql·nginx·docker·centos·mybatis
优创学社27 小时前
基于springboot的社区生鲜团购系统
java·spring boot·后端
why技术7 小时前
Stack Overflow,轰然倒下!
前端·人工智能·后端
幽络源小助理7 小时前
SpringBoot基于Mysql的商业辅助决策系统设计与实现
java·vue.js·spring boot·后端·mysql·spring
ai小鬼头8 小时前
AIStarter如何助力用户与创作者?Stable Diffusion一键管理教程!
后端·架构·github
简佐义的博客8 小时前
破解非模式物种GO/KEGG注释难题
开发语言·数据库·后端·oracle·golang
爬山算法8 小时前
MySQL(116)如何监控负载均衡状态?
数据库·mysql·负载均衡
Code blocks9 小时前
使用Jenkins完成springboot项目快速更新
java·运维·spring boot·后端·jenkins