shardingsphere的一个问题
最近shardingsphere更新了5.0.0版本,加入了很多新特性,所以我在自己的练习项目中想启动配置启动一下,但是并不是那么顺利,升级之后就直接无法启动了,根据错误栈提示是找不到一个名为ModeConfiguration的配置类的实例导致无法正常启动,经过查询官网的文档得知,5.0.0加入和mode配置,这个配置貌似是一个必须项,应该是持久化配置的一个作用,在shadingsphere的官网中有介绍。
shardingshpere官网关于mode的描述
spring:
shardingsphere:
datasource:
names: master
master:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/membership
username: membership
password: membership
mode:
type: Memory
schema:
name: membership
但是假如mode和schema的配置之后还是无法正常启动,项目又报了空指针异常,经过打断点发现在shardingshpere的org\apache\shardingsphere\driver\jdbc\core\datasource\metadata\ShardingSphereDatabaseMetaData.class 中进行初始化时,父类AdaptedDatabaseMetaData的cachedDatabaseMetaData为空,导致启动的失败,调用这个类的方法是flyway模块进行初始化脚本时调用的。目前暂时怀疑是少了某些配置项导致shardingjdbc没有正确加载cachedDatabaseMetaData。
经过在github社区的询问,5.0.0修改了一部分代码,导致如果没有配置rules那么就会无法正常启动,所以必须配置好rules相关分库分表策略才能正常启动服务