配置中心里面的配置变了之后,该怎么让 bean 用新的配置创建 client 之类的?

51 天前
 boris1993Jr

我们有个项目,现在是把各种配置放在 properties 文件里,文件包含连接其他服务的地址、账号、密码之类的,如果配置有变化就改文件然后重新部署

现在我们想要把这些配置放到配置中心里,但是现在遇到个问题是,假如说配置的密码变了,虽然我现在再取值能拿到新的密码,但是 bean 里面用的已经创建好的 client 还是在用老的密码去连

试过监听到配置刷新事件后就在 Spring 的 bean registry 里 destroy 再 register singleton ,但是会报 there is already object [xxx] bound

所以请问下我怎么样能让 bean 在配置刷新之后重建里面的各个 client ?

谢谢!

1005 次点击
所在节点    程序员
2 条回复
zhovy
50 天前
当配置中心中的配置发生变化时,需要让 Spring 容器中相关的 Bean 能够感知到这些变化,并重新初始化。在 Spring Cloud 中,你可以使用 @RefreshScope 注解来实现这一功能。这个注解可以使被标注的 Bean 在配置刷新时重新创建。

以下是如何使用 @RefreshScope 来实现你的需求:

添加依赖:
确保你的项目中包含了 Spring Cloud Config 的相关依赖,以及 Spring Cloud Context (它包含了 @RefreshScope 注解)。

标注 Bean:
在你想要重新创建的 Bean 上使用 @RefreshScope 注解。

java
@Component
@RefreshScope
public class MyClient {
// ...
}
触发刷新:
当配置中心中的配置发生变化时,你可以通过发送一个 POST 请求到 /actuator/refresh 端点来触发 Spring 应用的配置刷新。这会导致所有带有 @RefreshScope 注解的 Bean 被重新创建,并使用最新的配置。

安全性:
请注意,/actuator/refresh 端点默认是开放的,这可能会带来安全风险。你应该通过 Spring Security 来保护这个端点,只允许授权的用户或服务访问。

注意事项:
不是所有的 Bean 都适合使用 @RefreshScope 。特别是那些持有打开的资源(如数据库连接)或参与事务管理的 Bean ,在重新创建时可能会导致问题。确保你了解 Bean 的生命周期和依赖关系,并只在合适的地方使用 @RefreshScope

自定义配置源:
如果你使用的是自定义的配置源而不是 Spring Cloud Config ,你可能需要实现自己的配置刷新逻辑。这通常涉及到监听配置变化的事件,并在事件发生时重新加载或重建相关的 Bean 。

如果以上方法不能满足你的需求,你还可以考虑更复杂的解决方案,比如使用 Spring Cloud Bus 来在微服务集群中传播配置刷新事件,或者使用更底层的 Spring 生命周期管理 API 来手动管理 Bean 的生命周期。

最后,记得在测试环境中充分测试你的配置刷新逻辑,以确保它在生产环境中能够正常工作。
yuanxiaosong
50 天前
@EventListener(ContextRefreshedEvent.class)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1025126

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX