在我们企业中台建设中,注册中心升级到Nacos的架构演进中面临着一下几个比较现实的问题:

  • 存量用户如何迁移注册中心到 Nacos?
  • 多区域注册中心之间如何同步?
  • 已有注册中心与 Nacos 如何并存使用?

这里,我将通过对 Nacos Sync 的介绍,来回答这三个问题。

Nacos Sync 是什么?

Nacos Sync 是一个支持多种注册中心的同步组件,基于 SpringBoot 开发框架,数据层采用 Spring Data JPA,遵循了标准的 JPA 访问规范,支持多种数据源存储,默认使用 Hibernate 实现,更加方便的支持表的自动创建更新。

下图是 Nacos Sync 系统的概念图,Nacos Sync 通过从各个注册中心拉取注册的服务实例数据同步到 Nacos,左右两边是不同的注册中心,绿色代表目前是可以进行双向同步的,蓝色代表暂时只能进行单向同步。

 

image_20190421182457700

 

组件特性

Nacos Sync 使用了高效的事件异步驱动模型,支持多种自定义事件,使得同步任务处理的延时控制在3s,8C16G的单机能够支持6K的同步任务。

除了单机部署,Nacos Sync 也提供了高可用的集群部署模式,作为无状态设计,支持将任务等状态数据迁移到了数据库,使得集群扩展非常方便。

系统模块架构

下图是 Nacos Sync 目前的系统架构图,画的比较简单,只是把一些比较重要的模块做了描述。

 

image_20190421183229070

Web Console: 提供给用户进行注册中心和同步任务进行相关界面操作

Processor Frame: 注册中心和任务的业务处理逻辑

Timer Manager: 定时轮询数据库获取同步任务进行处理

Event Frame: 异步事件来进行同步任务的同步以及删除

Extension: 对接各种注册中心客户端的扩展实现

整体调用流程

我们来看一下 Nacos Sync 一次完整的调用流程:

 


image_20190421183544116

  1. 通过 Web 控制台添加相关注册中心,一般都必须配置两个注册中心,一个源注册中心,另外一个是目标注册中心,注册中心相关数据会写入到数据库;
  2. 添加完注册中心以后,增加一个同步任务,添加需要同步的服务(对于Dubbo来说就是RPC接口,对于Spring Cloud就是应用名);
  3. Nacos Sync 会每隔 3s 从数据库捞取同步任务,并通过异步事件的方式进行发布;
  4. 同步服务管理监听到定时任务发布的的事件,目前有同步/删除这两种事件;
  5. 同步服务管理根据不同的策略选择相关的同步服务进行真正同步逻辑处理;

目前已经支持同步类型

下面的表格介绍了目前支持的几种同步类型,并且说明了在 Dubbo 和 Spring Cloud 下是否支持同步,表格中列举的几种注册中心,无论单向还是双向同步都是在和 Nacos 进行交互。

 

image_20190421191720201

使用场景和 Demo

  • 多个网络互通的 Region 之间进行服务共享,打破 Region 之间的服务调用限制;

 

image_20190421192139580

  • 双向同步功能,支持 Dubbo+ZooKeeper 服务平滑迁移到 Dubbo+Nacos ;

 

image_20190421192204261

这里提供两个 Demo ,用来分别演示上面的两个经典使用场景,详细的操作步骤可以通过下方链接,进行访问。

单向同步场景,在 Spring Cloud 生态中,Eureka 同步到 Nacos 示例
https://github.com/paderlol/nacos-sync-example/tree/master/one-way-sync

双向同步场景,在 Dubbo 生态中 ZooKeeper 与 Nacos 互相同步示例
https://github.com/paderlol/nacos-sync-example/tree/master/two-way-sync

版本演进

Nacos Sync 目前已经发布3个小版本,通过下图,我们可以看到每个版本已经做了的一些工作,以及下个版本即将做的一些事情。

 

image_20190421192920320

 

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐