替代Eureka,你可以试试Consul

开发 架构
Eureka 1.x作为一个服务注册中心,有一个非常典型的架构问题。虽然他可以部署集群架构,但是集群中每个Eureka实例都是对等的。

1、Eureka官方宣布2.x不再开源

​如果对Spring Cloud微服务技术体系有一定了解了之后,肯定就知道Spring Cloud最开始原生支持和推荐的服务注册中心是国外的一个视频网站Netflix开源的Eureka。

这个Eureka呢,又分成了所谓的1.x版本和2.x版本,之前在国内比较常用在生产环境中的都是Eureka的1.x版本。

然后Netflix这个公司本身一直在做Eureka 2.x版本,结果做着做着,大家万众瞩目很期待的时候。。。

2018年7月,人家官方就突然宣布Eureka 2.x停止开源计划了,具体如下:

用中文给大家翻译一下,这里的意思就是说:Eureka 2.0的开源工作已经停止了,如果你要用Eureka 2.x版本的代码来部署到生产环境的话,一切后果请自负。​

大概就是这个意思,就是不打算把这个事儿做大做强下去了。

当然现在其实Eureka 1.x的版本也有不少公司在生产环境用,而且基本也还算能用的状态,基本功能还算正常,应付很多常规的场景也足够了。

但是现实就是这个声明发出来,让大伙都心里一凉,怎么感觉这个这个Eureka有点不太靠谱了呢,咱还敢继续用么,没错,很多小伙伴就是这感觉。

2、互联网大厂的基础架构:自研服务注册中心

这里给大家说一句题外话,BAT、TMD等一线互联网公司,包括一些有一定研发实力的中大型互联网公司,都是自研了微服务技术架构中的服务注册中心。或者是基于开源的Eureka之类的项目来做二次开发,自行优化里面的架构,解决遇到的问题。

所以对于有基础架构团队的公司而言,这个问题相对来说还没那么严重。

因为大厂的基础架构团队,完全可以把常见的开源服务注册中心的源码都深入看一遍,然后经过大量严谨的测试找到各个开源技术的优点和缺点。最后决定是从0开始自研一个服务注册中心,还是说基于某个开源的技术来进行二次开发和优化。

​比如说Eureka 1.x作为一个服务注册中心,有一个非常典型的架构问题。

虽然他可以部署集群架构,但是集群中每个Eureka实例都是对等的。每个Eureka实例都包含了全部的服务注册表,每个Eureka实例接收到了服务注册/下线等请求的时候,会同步转发给集群中其他的Eureka实例,实现集群数据同步。

大家看下面的图,大概就是一个示意。​

那么这里就有一个问题了:如果是支持超大规模的服务集群,这样的模式能行么?

每台机器的内存是有限的,集群里的服务数量越来越多,可能有几十万个服务实例在运行,那么服务注册表越来越大,最后超过单机内存支撑的极限怎么办?

这个时候如果自己研发服务注册中心,就可以参考大数据领域的Hadoop的架构思想。

Hadoop的设计思想是把注册表分片存储,分布式存储在多台机器上,每台机器存储部分注册表数据。

然后每个Server可以加上一个从节点做热备份,避免单机挂掉导致注册 表数据丢失。

我们来看看架构图,如下所示:

实际在生产环境使用Eureka的时候,你还会碰到很多现实的问题。

比如说上面讲了,Eureka本身是基于简单的同步机制实现集群架构的,但是这里在集群之间进行同步的时候,其实是异步进行的,采用的是最终一致性的协议。

这就可能会导致说,你某个服务注册到了一个Eureka Server实例上去,但是他需要异步复制到其他的Eureka Server,这中间是需要时间的。

所以可能导致其他的Eureka Server是看不到那个刚新注册的服务实例的。

大家看下面的图,就示意了这个问题:

但是如果是采取了类似Hadoop的那种数据分片思想的话,一个注册表数据分片就在一台机器上,由这台机器负责提供服务的注册和发现,那么此时就可以实现强一致的效果。

也就是说,只要你注册了,立马就会被别人发现,如下图。

这里只是说其中几个例子罢了,改造开源系统的思路是很多的,实际上大厂完全可以对开源技术做很多的自研、定制和改造,解决线上的生产问题,让服务注册中心朝着他们心里期望的效果去发展,所以对他们来说其实问题并不大。

3、中小公司的其他选择:Consul

只是对于很多中小型公司而言,可能本身没有基础架构团队的支撑,或者是没有过多的人力物力投入到自研中间件、开源系统二次开发中去。

那么此时就可以考虑选择其他的开源服务注册中心的技术了,比如Spring Cloud同样支持的Consul就是目前很多公司的选择。

这儿咱们简单介绍一下Consul,后面可以考虑再写文章介绍介绍Consul的架构原理和使用什么的,大家看一下,可以作为一个服务注册中心技术选型的参考:

  • 服务注册与发现

(1)Consul当然是可以作为服务注册中心的了,可以用做微服务架构的服务注册和发现。

(2)同时这里可以先给大家说一下,Consul的服务注册机制选择的是基于Daft协议的强一致,没有像Eureka那样使用最终一致的效果。

  • 健康检查

(1)Consul可以支持非常强大的健康检查的功能,啥叫健康检查?

(2)简单来说就是不停的发请求给你的服务检查他到底死了没有,目前是否还健康,这个就是叫做健康检查。

  • kv存储

(1)Consul不光支持服务注册和发现,居然还可以支持简单的kv存储。

(2)他可以让你用key-value对的形式存放一些信息以及提取查询,是不是很神奇?

  • 安全的服务通信

(1)Consul支持让你的服务之间进行授权来限制哪些服务可以通信和连接。

  • 多数据中心支持

其实说实话,在做技术选型的时候,非常关键的一点,就是看社区是否活跃。

所以虽然上面说了很多,但是其实大家完全可以看一眼下面的Eureka Github和Consul Github的更新活跃度的对比。

我们明显会发现,Eureka 1.x版本最近的更新都在几个月前甚至几年前,但是Consul最近的更新很多都是几天前的。

所以本身Spring Cloud官方技术栈也是支持Consul的,Eureka开源社区慢慢不再活跃之后,自然很多中小公司开始选择使用功能更加强大,而且社区更新也更加活跃的Consul作为服务注册中心了,这也是一个不错的选择。

责任编辑:姜华 来源: 今日头条
相关推荐

2021-05-28 06:19:22

ZooKeeperConsulNacos

2020-06-29 07:58:18

ZooKeeperConsul 注册中心

2023-09-05 07:47:14

.NET 7.0内存缓存

2021-01-28 11:40:34

Dubbo异步配置

2021-11-30 10:38:09

splitStringTokenJava

2017-06-25 13:33:25

Spring Clou微服务架构

2021-08-30 19:00:46

静态CompletableCountDownLa

2014-11-28 16:04:36

浪潮

2014-02-21 15:17:23

云存储Time Machin

2022-03-24 10:54:33

Piwigo开源

2022-02-14 23:43:33

大数据风险数据

2022-02-09 07:44:30

Go源码工具

2022-01-26 07:18:57

工具GoGo 项目

2021-09-30 16:17:42

开源软件视频通话视频会议

2023-05-30 14:54:17

Python循环语句工具

2010-03-03 14:36:01

Linux bridg

2024-03-11 08:21:49

2023-08-01 07:45:52

2021-09-22 09:14:33

Linux编程Visual Stud

2021-01-05 08:35:24

GNU nanoVim编辑器
点赞
收藏

51CTO技术栈公众号