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%';

如下图:



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

如图:

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

4. 重启项目

再次启动项目,就成功了
 

参考:

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

  • 24
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值