记录shardingsphere 5.0.0的一个问题

在尝试升级ShardingSphere到5.0.0版本时遇到启动困难,错误提示与ModeConfiguration配置类有关。官方文档表明Mode配置为必填项,已尝试配置但问题依旧,项目启动时出现空指针异常,原因是cachedDatabaseMetaData未被正确加载,可能由于缺少rules配置。在GitHub社区了解到,5.0.0版本要求必须配置rules以确保服务正常启动。
摘要由CSDN通过智能技术生成

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相关分库分表策略才能正常启动服务

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值