微服务注册中心简介
欢迎大家关注 github.com/hsfxuebao ,希望对大家有所帮助,要是觉得可以的话麻烦给点一下Star哈
1. 微服务注册中心简介
1.1 什么是微服务注册中心
提供者将自己提供服务的名称及自己主机详情(IP、端口等)写入到另一台主机中的一个列表中,这个
列表称为服务注册表
;所有消费者需要调用微服务时,首先从这台主机中将服务注册表下载到本地
,然
后根据消费者本地设置好的负载均衡策略选择一个服务提供者进行调用
。那么,这台主机就称为微服务 注册中心
。
1.2 注册中心架构
1.3 注册中心的主要功能
微服务注册中心的主要功能主要有以下几点:
实现provider与consumer间的解耦合
。提供者对于消费者来说是透明的,不固定的- 使消费者调用提供者实现负载均衡成为可能
- 通过微服务注册中心的Dashboard监控微服务的运行状态
1.4 常见的注册中心
可以充当服务注册中心的服务器很多,但一般情况下,不同的微服务生态,使用不同的注册中心。
- 若微服务使用的是
Dubbo
,一般注册中心使用Zookeeper
- 若微服务使用的是
Spring Cloud
,一般注册中心使用Eureka或Consul
- 若微服务使用的是
Spring Cloud Alibaba
,一般注册中心使用Nacos
2. 常见注册中心简介
2.1 Zookeeper
ZooKeeper由雅虎研究院开发,后来捐赠给了Apache。ZooKeeper是一个开源的分布式应用程序协调服 务器,其为分布式系统提供一致性服务。其一致性是通过基于Paxos算法的ZAB协议完成的。其主要功 能包括:配置维护、命名服务、分布式同步、集群管理、DNS服务、Master选举、分布式锁、分布式队 列等。其中DNS服务就是提供的注册中心服务。
2.2 Eureka
Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的
中间层服务,以达到负载均衡和中间层服务故障转移的目的
。SpringCloud将它集成在其子项目springcloud-netflix中,实现SpringCloud的服务发现功能。
现在的有关eureka 2.0的开源工作已经终止
。已经发布的现存库中的关于2.x分支部分的代码库与工程,
你的使用将自负风险。
Erueka 1.x是Netflix服务发现系统的核心部分,其仍是一个活跃项目
。
2.3 Consul
Consul 是 HashiCorp 公司推出的开源工具,用于实现分布式系统的服务发现与配置。使用Go语言编 写,使用Key/Value存储,采用Raft一致性协议,支持多数据中心。
2020年5月,HashiCorp公司官方宣布,不允许中国境内使用、部署和安装该企业旗下的产品和软件。 其中就包含Consul。不过,现在的官方声明中已看不到此限制了。下面是官方声明链接: www.hashicorp.com/terms-of-ev…
2.4 Nacos
Nacos,Dynamic Na
ming and Co
nfiguration S
ervice,动态命名与配置服务
。
Nacos是阿里巴巴开源的一款支持服务注册与发现,配置管理以及微服务管理的组件。用来取代以前常
用的注册中心(zookeeper , eureka等等),以及配置中心(spring cloud config等等)。Nacos是集成 了注册中心和配置中心
的功能,做到了二合一。
Nacos = 服务注册中心 + 服务配置中心
= Eureka + Spring Cloud Config + Spring Cloud Bus + Kafka/RabbitMQ
2.5 注册中心对比
比较项 | ZOOKEEPER | EUREKA | CONSUL | NACOS |
---|---|---|---|---|
CAP | CP | AP | CP | CP/AP |
一致性算法 | Paxos | - | Raft | Raft |
自我保护机制 | 无 | 有 | 无 | 有 |
SpringCloud集成 | 支持 | 支持 | 支持 | 支持 |
Dubbo集成 | 支持 | 不支持 | 支持 | 支持 |
K8S集成 | 不支持 | 不支持 | 支持 | 支持 |
接下来,我们将陆续重点分析Eureka 1.10.11 和Nacos的源码分析。
参考文章
eureka-0.10.11源码(注释) springcloud-source-study学习github地址 Eureka源码解析