构建微服务架构的系统,就会出现很多相似的逻辑,比如说api的调用,数据库的增删改查。
所以经常需要构建一个common的jar包去抽出共通部分,加强代码的重用。
例如:
一个message driven的信息变更推送系统。
message.pom
- message-common.pom
- message-process.pom
- message-api.pom
其中message-process 与 message-api 都需要访问数据库 调用外部api, 而这2中逻辑都可以 在message-common中定义出来。
而在message-process 与 message-api 中的 Application.java 中只需要引入需要实例化bean的外部包名就好了,
例如:
@ComponentScan(basePackages = {"com.messge.process", "com.messge.common"}) public class MessageProcessApplication { ... }
这样的话common 包中的实例就可以在process中直接引用了
但是如果common中还定义了一些process中不使用的bean 该如何排除呢?
可以使用ComponentScan中的 exclude属性排除调。
这里推荐一种更优雅的解决办法:@Import
我们可以将common包中的bean分组放入相应的configuration文件中,然后将这个功能集的config文件 引入到process 的application.java中
例如:common中创建configuration 类
@Configuration @EnableJpaAuditing @EnableJpaRepositories(basePackageClasses = MessageRepo.class) @EntityScan(basePackageClasses = MessageEntity.class) public class MessageProcessConfig { @Bean public RetryHelper retryHelper(@Value("${retry.max_attempts:5}") long maxAttempts, @Value("${retry.min_backoff:50ms}") Duration minBackoff){ return new RetryHelper(maxAttempts,minBackoff); } @Bean public ApiService apiService(RetryHelper retryHelper){ return new ApiService(retryHelper); } }
而这个功能集要在process中重用,就可以:
@SpringBootApplication @Import({MessageProcessConfig.class}) public class MessageProcessApplication { ... }
这样 common中的其他bean就不会在process启动的时候创建。
原文:https://www.cnblogs.com/lgtrajectory/p/14013167.html