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

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

一、快照数据

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

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

二、主从数据同步

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

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

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

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

三、测试

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

向主节点8084注册服务

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

相关推荐
万里侯3 分钟前
云原生安全扫描:保护容器化应用的安全
微服务·容器·k8s
万里侯11 小时前
GitOps实战:用Git管理基础设施
微服务·容器·k8s
逍遥德21 小时前
SpringBoot自带TaskScheduler 接口使用详解:(02)微服务多实例模式下,爆发任务重复执行问题
spring boot·分布式·后端·微服务·中间件
weixin_408318041 天前
企业级直播平台技术选型与成本分析:三种方案架构对比
微服务·云原生·架构
万里侯1 天前
K8s和我:一人一狗的日常冒险
微服务·容器·k8s
万里侯1 天前
Kubernetes Helm Chart开发最佳实践:打造可复用的应用包
微服务·容器·k8s
沪漂阿龙1 天前
Spring Cloud 面试题深度解析:微服务架构、注册中心、配置中心、Gateway、OpenFeign、负载均衡、熔断降级全攻略
spring cloud·微服务·架构
万里侯1 天前
分布式系统设计原则:构建高可用的系统架构
微服务·容器·k8s
万里侯2 天前
微服务与人生:从服务网格看人际关系
微服务·容器·k8s
小码哥0682 天前
一套可复用的打车系统模板,微服务版网约车系统|类似滴滴的打车平台
微服务·云原生·架构·滴滴·打车