![](/img/trans.png)
[英]Forcing external java (jar project) library beans to be managed by Spring fabric
[英]Spring external library beans initialization order
我在我的应用程序中遇到了一个问题,不知何故我需要强制一个 bean A 在另一个 bean B 之前初始化。这些 bean 是由外部依赖项(不同的依赖项)提供的,所以我不能简单地使用@DependsOn
注释来完成。
有没有可用的解决方案?
我设置了一个简单的(模块化的,maven)项目,并且在“外部组件”上使用@DependsOn
注释没有遇到任何问题。 只需要完成几件事:
A
在B
的(运行时)类路径中。B
的应用程序上下文@ComponentScan
s(也) A
。A
,在你使用该值@DependsOn
注解。 ..then @DependsOn
按预期工作(也适用于“外部依赖项”)。该示例使用spring-boot ,但(我确信)配置详细信息适用于“无引导”环境/上下文。
并考虑 DependsOn 的 javadoc:
在 bean 不通过属性或构造函数参数显式依赖另一个 bean,而是依赖另一个 bean 初始化的副作用的情况下,很少使用。
@Autowired
会给你同样的效果(用类似的努力),但类型安全/没有“名字猜测” - 我将它添加到示例中。
返工:关于这个来自第三个项目 (baz),您再次有几个选项可以在B
之前强制A
初始化。
如果A
和B
初始化是微不足道的(例如默认构造函数),您可以像这样继续配置/应用程序:
import ...A; import ...B; ... @Configuration// @SpringBootApplication ..or idempotent public class MyConfig { ... @Bean("a") public A a() { return new A(); } @Bean @DependsOn("a") public B b() { return new B(); } ... }
如果初始化(A 和 B)不是微不足道的,但您可以参考现有的(外部)配置,那么这有效(重新定义自动装配的 bean,添加 dependsOn 注释):
@Configuration @Import(value = {BConfig.class, AConfig.class}) class MyConfig { @Bean("a") public A a(@Autowired A a) { return a; } @Bean @DependsOn("a") public B b(@Autowired B b) { return b; } }
您依赖于组件扫描,并重新定义 bean(使用dependsOn):
@Configuration @ComponentScan(basePackageClasses = {B.class, A.class}) class MyConfig { // same as 2. }
如果外部配置 (2., 3.) 定义了具有相同“名称” spring.main.allow-bean-definition-overriding
,则spring.main.allow-bean-definition-overriding
属性必须设置为true
(在 application.properties 或幂等中)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.