Soul网关同步数据之Zookeeper

2024-06-05 17:48

本文主要是介绍Soul网关同步数据之Zookeeper,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Soul网关同步数据之Zookeeper

调整配置

pom文件中注释掉原来默认的websocket同步方式,改为zookeeper同步。

        <!--soul data sync start use zookeeper--><dependency><groupId>org.dromara</groupId><artifactId>soul-spring-boot-starter-sync-data-zookeeper</artifactId><version>${project.version}</version></dependency><!--soul data sync start use websocket--><!--<dependency>--><!--<groupId>org.dromara</groupId>--><!--<artifactId>soul-spring-boot-starter-sync-data-websocket</artifactId>--><!--<version>${project.version}</version>--><!--</dependency>-->

同理注释掉yml问价中的默认的websocket配置修改为zookeeper配置

    zookeeper:url: localhost:2181sessionTimeout: 5000connectionTimeout: 2000

对应的网关soul-bootstrap层根据官方文档做对应的设置

根据上一文的调试过程。我们同样找到了zookeeper对应的配置文件和加载的代码 file 从传递格式可以看到与websocket的同步的配置基本一样,但是同样的,我在这里断点调试时 final ObjectProvider pluginSubscriber组件的数据来源有一些疑问。因此我全局搜索了PluginDataSubscriber,发现了实现了PluginDataSubscriber接口的类CommonPluginDataSubscriber,发现在这个类中有事件订阅和刷新相关的方法。毫无疑问,这些就是后续再具体操作时实现数据变化刷新时的关键逻辑 紧接着。我发现CommonPluginDataSubscriber类上并没有Spring中相关的注解。那么他是如何被注入到spring中的呢。于是我又进行了全局搜索,发现这个类在soul-web模块中的SoulConfiguration模块中进行了注入

@Bean public PluginDataSubscriber pluginDataSubscriber(final ObjectProvider<List > pluginDataHandlerList) { return new CommonPluginDataSubscriber(pluginDataHandlerList.getIfAvailable(Collections::emptyList)); }

 同时可以发现这个类中有其他转发和插件处理等相关逻辑。这个后续的分析可能会用到,值得关注一下另外可以看到上述列表中同样适用了ObjectProvider来注入插件数据处理类。利用这个线索。我们可以全局搜索一下PluginDataHandler相关的类,搜索后发现,基本每一个插件都是类似的这种做法Configuration-->PluginDataHandler

同时,可以知道数据流向RateLimiterConfiguration-->RateLimiterPluginDataHandler-->SoulConfiguration-->pluginDataSubscriber-->ZookeeperSyncDataConfiguration

同时在ZookeeperSyncDataService我们可以看到基于zookeeper的客户端进行了选择器和规则,元数据和权限相关的数据同步操作。关于这一部分的内容,后续我们继续查看如何进行的数据同步 同时,后面我们会讲解一些关于响应式编程的相关内容,例如Mono和Flux

欢迎搜索关注本人与朋友共同开发的微信面经小程序【大厂面试助手】和公众号【微瞰技术】,以及总结的分类面试题https://github.com/zhendiao/JavaInterview

file file

这篇关于Soul网关同步数据之Zookeeper的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1033754

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L