org.quartz.impl.jdbcjobstore.LockException: Failure obtaining db row lock: Table ‘india_framework.QR

1. 报错原因:

将Windows上的mysql数据迁移到Linux上后,报这个错:

org.quartz.impl.jdbcjobstore.LockException: Failure obtaining db row lock: Table 'india_framework.QRTZ_LOCKS' doesn't exist

2. 分析:

首先用windows的mysql是没问题的。
其实linux的mysql也是有这个表的,但由于是从windows复制过去的,所以表名都是小写的,而quartz启动的时候找的是大写,所以认为test.QRTZ_LOCKS这个表不存在。
原理就在于mysql有个配置属性:lower_case_table_names
windows上安装mysql,默认是1,代表忽略大小写
linux上安装mysql,默认是0,代表不忽略大小写
所以在windows好好的,在linux上就报错了。
 

3. 解决方法

方法1:

  • 最快的解决办法,就是将所有quartz开头的表,都换成大写就好了

方法2:

让linux也像windows一样,忽略大小写。
具体就是设置linux上的lower_case_table_names=1,就和windows一样了。步骤如下:

1、先执行sql查看lower_case_table_names的值:

show variables like '%lower_case_table_names%';

如下图:

org.quartz.impl.jdbcjobstore.LockException: Failure obtaining db row lock: Table ‘india_framework.QR_第1张图片

2、修改/etc/my.cnf文件,在文件末尾加lower_case_table_names=1,如下图。

cd /etc
vim my.cnf

wq:保存退出

末尾加上:

lower_case_table_names=1  

wq:保存退出

重启mysql服务:

service mysqld restart

如图:

org.quartz.impl.jdbcjobstore.LockException: Failure obtaining db row lock: Table ‘india_framework.QR_第2张图片

3、重启mysql后,再次查看:lower_case_table_names的值

org.quartz.impl.jdbcjobstore.LockException: Failure obtaining db row lock: Table ‘india_framework.QR_第3张图片

4. 重启项目

再次启动项目,就成功了
 

参考:

————————————————
版权声明:本文为CSDN博主「zhangSir134」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/java_zhangshuai/article/details/108804397

你可能感兴趣的:(日常报错记录,数据库)