问题1
项目启动报错
java.sqlSQLException: There is no DataSource name ‘null’
SchedulerConfigException:DataSource name not set
分析并解决
配置中心配置的quartz配置代码中可以获取到,便排除了远程配置获取失败问题。
于是进行断点调试,将断点打在quartz的配置类中,断点也能进来,但是在断点之前,就抛出了错误,于是怀疑是否是spring bean加载的问题,获取不到配置的数据源,于是各种查询无果。最后请教大佬解决的。
大佬思路:
因为在quartz中创建了ScheduleFactory,且在这个bean创建前就报错,就认为是不是获取配置文件有问题,然后断点打在获取配置文件的地方,寻找是否还有其他本地配置,结果查找到,在启动类的模块中,藏有一个quartz.properties文件,本地配置文件的加载会优先于远程配置文件
最后解决便是,删除这个本地文件,报错解决!!!(裂开)
总结:
1:断点的地方不对,导致一层一层找不出问题
2:在代码中能获取到远程配置的值,便觉得配置没有问题,殊不知
本地配置文件中有的值,就不会使用远程的
(待验证),刚好我看到的值使本地配置没有的。
问题2
项目启动后
java.sql.SQLException:No suitable driver
分析并解决
yml和properties文件转义问题
在properties文件中,对于特殊配置例如:
数据库url:jdbc:mysql://ip:3306/ 是需要转义的
但是在yml中,不需要转义
总结:
properties文件需要转义,yml不需要