概述

注册中心是 Dubbo 服务治理的核心组件,Dubbo 依赖注册中心的协调实现服务(地址)发现,自动化的服务发现是微服务实现动态扩缩容、负载均衡、、流量治理的基础。Dubbo 的服务发现机制经历了 Dubbo2 时代的接口级服务发现、Dubbo3 时代的应用级服务发现,具体可参见 服务发现机制 解析了解具体演进过程。

基本使用

开发应用时必须指定 Dubbo 注册中心(registry)组件,配置很简单,只需指定注册中心的集群地址即可:

以 Spring Boot 开发为例,在 application.yml 增加 registry 配置项目

  1. dubbo
  2. registry
  3. address: {protocol}://{cluster-address}

其中,protocol 为选择的配置中心类型,cluster-address 为访问注册中心的集群地址,如

address: nacos://localshot:8848

如需集群格式地址可使用 backup 参数

address: nacos://localshot:8848?backup=localshot:8846,localshot:8847

应用必须指定 Dubbo 注册中心,即使不启用注册中心也要配置(可通过设置地址为空 address=‘N/A’ )。

除了 其余根据每个配置中心的不同,可以参考 registry 配置参考手册或通过 parameters 参数进行扩展。

配置中心与元数据中心

配置中心、元数据中心是实现 Dubbo 高阶服务治理能力的基础组件,相比于注册中心通常这两个组件的配置是可选的。

为了兼容 2.6 及老版本的配置,对于部分注册中心类型(如 Zookeeper、Nacos 等),Dubbo 会同时将其用作元数据中心和配置中心。

  1. dubbo
  2. registry
  3. address: nacos://localhost:8848

框架解析后的默认行为

  1. dubbo
  2. registry
  3. address: nacos://localhost:8848
  4. config-center
  5. address: nacos://localhost:8848
  6. metadata-report
  7. address: nacos://localhost:8848

可以通过以下两个参数来调整或控制默认行为

  1. dubbo
  2. registry
  3. address: nacos://localhost:8848
  4. use-as-config-center: false
  5. use-as-metadata-report: false

注册中心生态

Dubbo 主干目前支持的主流注册中心实现包括

  • Zookeeper
  • Nacos
  • Redis

同时也支持 Kubernetes、Mesh 体系的服务发现。

另外,Dubbo 扩展生态 还提供了 Consul、Eureka、Etcd 等注册中心扩展实现。也欢迎通过 registry spi 扩展 贡献更多的注册中心实现到 Dubbo 生态。

Dubbo 还支持在一个应用中 指定多个注册中心,并将服务根据注册中心分组,这样做使得服务分组管理或服务迁移变得更容易。

最后修改 December 16, 2022: Fix check (#1736) (97972c1)