从0到1手写注册中心Registry之主从数据同步

集群选主完成后,从节点需要从主节点同步数据。

一、快照数据

同步的快照数据是描述注册中心的服务信息。

  • registry: 每个服务对应的实例;
  • versions:每个服务的版本信息;
  • timestamps:每个服务的时间戳;
  • version:当前服务版本信息;

二、主从数据同步

在定时任务中,依次执行:服务状态更新,集群选主,主从数据同步。

当前节点不是主节点,并且版本信息小于主节点的版本,就认为是从节点,就需要从主节点同步数据,以保证整个集群对外数据的一致性。

发起http请求,获取快照数据,然后根据快照数据恢复到当前从节点注册中心数据。

恢复数据的逻辑就是清空,再添加。

三、测试

依次启动8084、8085、8086,主节点是8084,从节点是8085和8086。

向主节点8084注册服务

从节点8086也能查询到服务,说明主从数据同步成功。

相关推荐
HLAIA光子23 分钟前
分布式锁与事务:你的微服务可能根本不需要它们
分布式·后端·微服务
heimeiyingwang1 小时前
【架构实战】注册中心选型:Nacos vs Eureka vs Consul
微服务·云原生·架构
Jabes.yang2 小时前
互联网大厂Java求职面试实战解析(含技术场景与详解)
spring boot·微服务·面试·orm·技术栈·java se·jakarta ee
Java识堂19 小时前
如何对微服务进行拆分?
微服务·云原生·架构
就改了21 小时前
微服务接口性能优化:CompletableFuture 并行聚合实践
java·微服务·性能优化
丑过三八线1 天前
Runc 深度解析:从原理到实操
java·linux·开发语言·docker·容器·rpc
2601_961845151 天前
专升本资料哪个好|教材+真题+网课对比推荐PDF
考研·http·微服务·容器·visual studio
heimeiyingwang1 天前
【架构实战】网关架构设计:微服务的统一入口
微服务·云原生·架构
真实的菜1 天前
微服务架构痛点
java·微服务·架构