Waiting for table metadata lock引发java.sql.SQLException: No operations allowed after statement closed

项目场景:

应用报错java.sql.SQLException: No operations allowed after statement closed


问题描述

接口报错后,show processlist 检查数据库,发现等待锁释放 Waiting for table metadata lock
在这里插入图片描述


原因分析:

mysql中如果一个表产生了Waiting for table metadata lock,针对表的任何操作都会被锁住,包括select,可以通过配置参数lock_wait_timeout减少等待时长。No operations allowed after statement closed原因是存在未提交事物,阻塞DDL,继而阻塞所有同表的后续操作

问题复现:

未提交事务:

begin;
select * from resource_yarn_queue_metadata limit 1;

DDL操作(表是一个分区表,通过自动化脚本定时新增分区)

ALTER TABLE resource_yarn_queue_metadata ADD PARTITION (
    PARTITION p20240610 VALUES LESS THAN (739413)
);

解决方案:

查找未提交事务id,kill

select t.PROCESSLIST_ID,
       t.PROCESSLIST_USER,
			 t.PROCESSLIST_HOST,
			 t.PROCESSLIST_DB,
			 t.PROCESSLIST_STATE,
			 t.PROCESSLIST_COMMAND,
			 t.PROCESSLIST_TIME,
			 t.PROCESSLIST_INFO,
			 e.CURRENT_SCHEMA,
			 GROUP_CONCAT(e.SQL_TEXT SEPARATOR ' ') as sqL_text
from performance_schema.threads t,
		 information_schema.INNODB_TRX trx,
		 performance_schema.events_statements_history e
where t.THREAD_ID = e.THREAD_ID
      and t.PROCESSLIST_ID = trx.trx_mysql_thread_id
group by t.THREAD_ID DESC;
kill 1125440;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

但行益事莫问前程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值