Spring Cloud第一篇 Eureka简介及原理
来源:互联网 发布:matlab矩阵拼接 编辑:程序博客网 时间:2024/05/22 22:45
Eureka是Netflix开发的服务发现组件,本身是一个基于REST的服务。Spring Cloud将它集成在其子项目spring-cloud-netflix中,以实现Spring Cloud的服务发现功能。目前Eureka 项目相当活跃,代码更新相当频繁,目前最新的版本是1.5.5。Eureka 2.0也在紧锣密鼓地开发中,2.0将会带来更强的功能和更好的扩展性,但是由于还没有Release,故而不作讨论。
本文讲解的Spring Cloud Camden SR1所使用的Eureka版本是1.4.11,还是比较新的。同时有了Eureka 1.x的基础,未来上手Eureka 2.x也会比较容易。
Eureka的Github:https://github.com/Netflix/Eureka
Region、Zone解析
Eureka的官方文档对regin、zone几乎没有提及,由于概念抽象,新手很难理解。因此,在分析Eureka原理之前,我们先来了解一下region、zone、Eureka集群三者的关系,如图4-2。
regin-zone-eureka
图4-2 region、zone、Eureka集群之间的关系
region和zone(或者Availability Zone)均是AWS的概念。在非AWS环境下,我们可以简单地将region理解为Eureka集群,zone理解成机房。这样图4-2就很好理解了——一个Eureka集群被部署在了zone1机房和zone2机房中。
对region和zone感兴趣的读者可前往http://blog.csdn.net/awschina/article/details/17639191 扩展阅读。Spring Cloud中默认的region是us-east-1 。
Eureka架构
eureka 架构
图4-3 Eureka架构图
图4-3是来自Eureka官方的架构图,大致描述了Eureka集群的工作过程。图中包含的组件非常多,可能比较难以理解,我们用通俗易懂的语言解释一下:
Application Service 相当于本书中的服务提供者,Application Client相当于本书中的服务消费者;
Make Remote Call,可以简单理解为调用RESTful API;
us-east-1c、us-east-1d等都是zone,它们都属于us-east-1这个region;
由图可知,Eureka包含两个组件:Eureka Server 和 Eureka Client,它们的作用如下:
Eureka Client是一个Java客户端,用于简化与Eureka Server的交互;
Eureka Server提供服务发现的能力,各个微服务启动时,会通过Eureka Client向Eureka Server进行注册自己的信息(例如网络信息),Eureka Server会存储该服务的信息;
微服务启动后,会周期性地向Eureka Server发送心跳(默认周期为30秒)以续约自己的信息。如果Eureka Server在一定时间内没有接收到某个微服务节点的心跳,Eureka Server将会注销该微服务节点(默认90秒);
每个Eureka Server同时也是Eureka Client,多个Eureka Server之间通过复制的方式完成服务注册表的同步;
Eureka Client会缓存Eureka Server中的信息。即使所有的Eureka Server节点都宕掉,服务消费者依然可以使用缓存中的信息找到服务提供者。
综上,Eureka通过心跳检测、健康检查和客户端缓存等机制,提高了系统的灵活性、可伸缩性和可用性。
- Spring Cloud第一篇 Eureka简介及原理
- Spring Cloud | 第一篇:服务注册与发现(Eureka)
- Eureka简介及原理
- 菜鸟之路spring cloud 学习|第一篇服务的注册与发现(eureka)
- spring-cloud-eureka (一) 原理分析
- Spring-Cloud系列第2篇:spring-cloud-eureka
- Spring-Cloud系列第3篇:spring-cloud-eureka-consumer
- 第一篇 Spring Cloud概述
- 深入Spring Cloud源码设计-eureka一篇就够
- spring cloud-eureka
- Spring-cloud Eureka 集群
- spring cloud eureka
- Spring Cloud Eureka
- Spring Cloud Netflix Eureka
- Spring Cloud Eureka详解
- Spring Cloud Eureka
- Spring Cloud Eureka
- spring cloud eureka
- 股神、餐馆拼桌问题
- mongodb 实现group by 多个key having count(*) >1
- redis 认证
- 银联规范的密钥体系
- Linux远程登录--ssh 和 vnc
- Spring Cloud第一篇 Eureka简介及原理
- Guava学习笔记:Range
- JS四舍五入函数保留小数点*
- FileReader文件读取API
- CodeForces
- iOS 转盘效果
- 为什么有时候C++运算符重载要返回引用,附对象生存周期
- C语言中static和extern用法的一个小细节
- Linux 进程的概念和管理