admin管理员组文章数量:1618692
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/myf文件,在文件末尾加lower_case_table_names=1,如下图。
cd /etc
vim myfwq:保存退出
末尾加上:
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/java_zhangshuai/article/details/108804397
本文标签: jdbcjobstoreLockExceptionfailureorgQuartz
版权声明:本文标题:org.quartz.impl.jdbcjobstore.LockException: Failure obtaining db row lock: Table ‘india_framework.QR 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dongtai/1728783148a1172984.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论