yaml中遇到的坑

遇到的问题

最近在使用sharding-jdbc 进行分表拆分,配置了分表规则在yaml上,但是发现最终入库的时候路由规则并未生效,便开始寻找bug。

解决问题的思路

由于从来没有遇到类似的问题,且有之前成功路由其他表的规则。首先怀疑是框架本身问题,于是按照以下思路进行排查:

  1. 首先读shard-jdbc关于路由部分源码
  2. 查看其他表是否能正常路由
  3. 更换路由字段和规则,看能够生效。

以上问题在第三点时发现更换其他字段可以正常路由,于是再仔细读shard-jdbc源码并调试。
最终发现在yml中配置的路由字段有问题,转义的时候破坏的字段的原有含义。原有配置如下:


                xxx:
                    actualDataNodes: ds.xxx$->{0..1}
                    tableStrategy:
                        inline:
                            shardingColumn: no
                            algorithmExpression: xxx$->{no % 2}

通过debug发现它在yml到java内存中时,将no映射为了false,故在shard-jdbc中路由发生故障,导致无法路由。yaml bool的关键字定义

总结

yaml规范中定义了很多关键字,我们在使用过程中应当尽量避免和yaml关键字冲突,这样在yaml解析过程中才能达到我们想要的效果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值