解决idea调试过程中liquibase –liquibase.lockservice: Waiting for changelog lock导致数据库死锁问题

文章描述了一个由于IDEA频繁运行导致的数据库死锁问题,具体表现为JAR包启动时工作流表和日志表被锁。Liquibase在等待变更日志锁。解决方案是查询并修改DATABASECHANGELOGLOCK表的locked字段为0来解除锁定。如果出现表不存在的错误,需检查所有类似命名的表并进行相同操作。
摘要由CSDN通过智能技术生成

 1.出现数据库死锁问题原因可能为idea运行时频繁,导致Jar包启动报错,工作流表部分日志表被锁,也可能上次未正常终止程序导致的异常

2023-03-20 14:43:06.599  INFO 21208 --- [main] liquibase.lockservice   : Waiting for changelog lock....
2023-03-20 14:43:16.878  INFO 21208 --- [main] liquibase.lockservice   : Waiting for changelog lock....
2023-03-20 14:43:27.225  INFO 21208 --- [main] liquibase.lockservice   : Waiting for changelog lock....
2023-03-20 14:43:37.628  INFO 21208 --- [main] liquibase.lockservice   : Waiting for changelog lock....
2023-03-20 14:43:48.026  INFO 21208 --- [main] liquibase.lockservice   : Waiting for changelog lock....
2023-03-20 14:43:58.592  INFO 21208 --- [main] liquibase.lockservice   : Waiting for changelog lock....
2023-03-20 14:44:09.105  INFO 21208 --- [main] liquibase.lockservice   : Waiting for changelog lock....

2.执行下面的第一条语句,查出的数据库中数据的locked的值是1,说明database被锁了,然后在执行第二条修改语句,进行修改

#查询被锁的表
SELECT * FROM DATABASECHANGELOGLOCK;
#解除锁定
UPDATE DATABASECHANGELOGLOCK SET locked=0, lockgranted=null, lockedby=null WHERE id=1

3.如果提示找不到表或试图不存在

解决办法(所有以DATABASECHANGELOGLOCK结尾的表都检查一遍,并修改locked字段的值为0即可)如图所示:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值