Spring中的配置如何保证可扩展性

公司项目引用了一个依赖jar,中的证配置封装太封闭了,配置不能扩展。何保业务变动一次那个jar就要跟着升级一次,扩展而且不同的中的证项目还引用了这个jar的不同版本。领导问我能不能给它搞成可扩展的配置,研究了一下,何保实现了可扩展定制化。扩展

原本的中的证配置类似是这样的:

@Configuration(proxyBeanMethods = false) public class MyConfiguration {      /**      * bean      */     @Bean     ConfigBean configBean(Config config)  {          //todo 逻辑      return new ConfigBean(config)     }      } 

如果想根据项目的服务器托管不同定制不同的ConfigBean就不太好弄了。如果能在Config对象传入ConfigBean构造之前放一个修改Config的配置口子就好了。这样ConfigBean的何保初始化生命周期也变成了

发现Config对象-> 修改Config对象-> 初始化ConfigBean 

于是我定义了一个可以修改Config对象的接口:

@FunctionalInterface public interface ConfigCustomizer {      /**      * Customize.      *      * @param config the config      */     void customize(Config config); } 

上面整个配置就变成这样的了:

@Configuration(proxyBeanMethods = false) public class MyConfiguration {      private List<ConfigCustomizer> configCustomizers = Collections.emptyList();     /**      * bean      */     @Bean     ConfigBean configBean(Config config)  {          // 其它公共逻辑省略         // 最后定制逻辑注入         configCustomizers                 .forEach(configCustomizer -> configCustomizer.customize(config));      return new ConfigBean(config)     }     @Autowired(required = false)     void setConfigCustomizers(List<ConfigCustomizer> configCustomizers) {          this.configCustomizers = configCustomizers;     } } 

这样我们需要改动配置时只需要声明一个ConfigCustomizerBean即可,它会被setConfigCustomizers自动发现并执行自定义的扩展方法。

这里会有朋友说@ConditionalOnMissingBean系列注解也能干这个事啊,中的证没错!这样我们完全可以声明一个新的配置ConfigBean取而代之。但是何保这是云南idc服务商两种策略:一种是修修补补就能用;一种是推到重来。我们在封装组件的时候要合理利用这些策略,该开口子的要开口子,不该开放的保持封闭,另外保证组件的扩展性也是很重要的。

本文转载自微信公众号「码农小胖哥」,可以通过以下二维码关注。转载本文请联系码农小胖哥公众号。

亿华云计算
数据库
上一篇:解析之后一般在十分钟内生效,如果没有生效可以联系域名服务商进行沟通。
下一篇:前面这两个步骤都是在本机完成的。到这里还没有涉及真正的域名解析服务器,如果在本机中仍然无法完成域名的解析,就会真正请求域名服务器来解析这个域名了。