背景
以往一直在程序中写死的mongodb查询collection,对于频繁改动的mongodb来说,每次更改都要进行代码修改,费时费力还有风险,故而希望使用动态配置的方式来进行collection查询。
以往映射关系如下:
由于需要动态配置,首先想到将collection信息存储在zookeeper配置中心里(项目组使用zk做配置中心),所以希望使用@Value的形式来获得,但是由于mongdb中Document不支持@Value的相关语法,所以需要使用表达式来动态支持。
SpEL概念
SpEL全称为“Spring Expression Language”,简写为“SpEL”,参考如下spring 官方文档:https://docs.spring.io/spring/docs/3.0.x/reference/expressions.html
基于SpEL实现mongodb动态配置,在网上资料不多,搜索到一篇文章,https://www.jb51.cc/spring/431546.html,下图为资料中内容
下图为本人项目中所定义的mongodbconfig
尝试1.将@Document注释更改为如下所示:
@Document(collection="#{@mongodbTableName.getTableName()}")
但是仍然存在问题,发现程序报错,报错信息如下:
org.springframework.expression.spel.SpelEvaluationException:
EL1057E: No bean resolver registered in the context to resolve access to bean 'mongodbTableName'
分析bean注册原因,经过检查,bean信息正常,并没有问题,所以分析是表达式问题,进而对表达式进行调整。
尝试2.将@Document注释更改为如下所示:
@Document(collection="#{mongodbTableName.getTableName()}")
结果发现又是新的问题,报错如下:
org.springframework.expression.spel.SpelEvaluationException: EL1007E:(pos 0): Property or field ‘mongodbTableName’ cannot be found on null
怀疑可能还是表达式书写问题,继续调整尝试,
尝试3.将@Document注释更改为如下所示:
@Document(collection="@mongodbTableName.getTableName()")
程序成功运行,初步分析,前面@mongodbTableName去获取spring中对应的bean信息,因为在bean中定义了getTableName(),且返回值为String类型,符合collection要求,实现了配置。