配置中心数据的获取-上
在介绍 link-flow 项目时,提到了路由参数可以通过请求头传递规则,也可以通过配置中心来配置规则,而且配置中心修改更为灵活。 link-flow 支持的配置中心有 Nacos 和 Apollo,本章节详细介绍是如何读取配置中心的规则的
当引入 link-flow 后,会在项目启动时就会从配置中心读取数据,那这个启动后的时机是通过什么机制来实现呢?答案就是 Spring的事件机制,定义了一个自定义事件,当项目启动后发布此事件,而接听此事件的接收者就会知道项目启动了。
关于Spring事件机制的详细介绍可跳转到 技术精华讲解-Spring的事件发布与监听 章节。
自定义事件
这里自定义了一个事件叫 ConfigEvent
public class ConfigEvent extends ApplicationEvent {
/**
* Create a new {@code ApplicationEvent}.
*
* @param source the object on which the event initially occurred or with
* which the event is associated (never {@code null})
*/
public ConfigEvent(final Object source) {
super(source);
}
}
事件发布者
事件定义好后,就要创建一个事件发布者 ConfigEventPush
public class ConfigEventPush implements ApplicationListener<ApplicationStartedEvent> {
@Override
public void onApplicationEvent(final ApplicationStartedEvent event) {
event.getApplicationContext().publishEvent(new ConfigEvent(this));
}
}
这里能看到有点复杂,怎么监听事件又发布事件?首先监听的这个 ApplicationStartedEvent 事件,是SpringBoot 自带的,它是在 SpringBoot 启动后自己就会发布此事件了,我们要做的就是直接监听这个事件即可,这样当 SpringBoot 启动后,就会自动的执行到监听 ApplicationStartedEvent 事件的逻辑了。
当监听到后,再来发布我们自己自定义的 ConfigEvent 事件。这里可以通过 ApplicationStartedEvent 来拿到发布事件所用到的上下文 ApplicationContext。
事件接收者
@AllArgsConstructor
@Slf4j
public class ConfigEventHandler implements ApplicationListener<ConfigEvent> {
private final MetaDataOperation metaDataOperation;
private final RemoteConfigRuleOperation remoteConfigRuleOperation;
@Override
public void onApplicationEvent(ConfigEvent event) {
getConfig();
remoteConfigRuleOperation.listenConfig();
}
//省略... ...
}
付费内容提示
该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放
加入星球后,你可以获得:
- 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
- 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
- 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
- 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
