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

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

一、快照数据

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

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

二、主从数据同步

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

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

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

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

三、测试

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

向主节点8084注册服务

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

相关推荐
喜欢流萤吖~5 小时前
服务间的依赖管理:微服务的协作之道
java·微服务
LSL666_10 小时前
微服务架构
微服务·云原生·架构
威迪斯特10 小时前
GoFr框架:加速微服务开发的Go语言利器
开发语言·后端·微服务·架构·golang·命令行框架·gofr框架
大龄码农-涵哥14 小时前
Spring Cloud微服务架构详解:从服务注册到配置中心,阿里面试核心知识点
spring cloud·微服务·架构
LSL666_14 小时前
微服务架构——有关概念
微服务·云原生·架构
小江的记录本14 小时前
【微服务与云原生架构】Serverless架构、FaaS/BaaS、核心原理、优缺点
java·后端·微服务·云原生·架构·系统架构·serverless
喜欢流萤吖~15 小时前
API包独立拆分:微服务的契约治理
微服务·架构
雪碧聊技术15 小时前
告别“复制粘贴”!微服务架构下如何统一管理POM依赖版本(实战详解)
微服务·云原生·架构
AI服务老曹15 小时前
【架构深度解析】从异构计算到微服务:构建支持 X86/ARM 与 GPU/NPU 协同的 GB28181 视频 AI 平台
arm开发·微服务·架构
weixin_397578021 天前
Docker Desktop → Docker CE 完整迁移部署方案
微服务