java架构师高端课微服务_02_SpringCloud_Netflix_Eureka
Spring Cloud Netflix Eureka
主要内容
Eureka简介
Eureka和Zookeeper 对比
搭建Eureka注册中心
Eureka 服务管理平台介绍
搭建高可用集群
集群原理
Eureka优雅停服
学习目标

Spring Cloud Netflix Eureka
一、 Eureka简介
Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的。
SpringCloud将它集成在其子项目spring-cloud-netflix中,以实现SpringCloud的服务发现功能。
1 Eureka组件
Eureka包含两个组件:Eureka Server和Eureka Client。
1.1 Eureka Server
Eureka Server提供服务注册服务,各个节点启动后,会在Eureka Server中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到。
Eureka Server本身也是一个服务,默认情况下会自动注册到Eureka注册中心。
如果搭建单机版的Eureka Server注册中心,则需要配置取消Eureka Server的自动注册逻辑。毕竟当前服务注册到当前服务代表的注册中心中是一个说不通的逻辑。
Eureka Server通过Register、Get、Renew等接口提供服务的注册、发现和心跳检测等服务。
1.2 Eureka Client
Eureka Client是一个java客户端,用于简化与Eureka Server的交互,客户端同时也具备一个内置的、使用轮询(round-robin)负载算法的负载均衡器。在应用启动后,将会向Eureka Server发送心跳,默认周期为30秒,如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,Eureka Server将会从服务注册表中把这个服务节点移除(默认90秒)。
Eureka Client分为两个角色,分别是:Application Service(Service Provider)和Application Client(Service Consumer)
1.2.1 Application Service
服务提供方,是注册到Eureka Server中的服务。
1.2.2 Application Client
服务消费方,通过Eureka Server发现服务,并消费。
注意:在这里,Application Service和Application Client不是绝对上的定义,因为Provider在提供服务的同时,也可以消费其他Provider提供的服务;Consumer在消费服务的同时,也可以提供对外服务。
二、 Eureka和Zookeeper 对比
1 什么是CAP定理
CAP原则又称CAP定理,指的是在一个分布式系统中,Consistency(数据一致性)、 Availability(服务可用性)、Partition tolerance(分区容错性),三者不可兼得。
CAP由Eric Brewer在2000年PODC会议上提出。该猜想在提出两年后被证明成立,成为我们熟知的CAP定理




2 基于CAP定理比对Eureka和Zookeeper





三、 搭建Eureka注册中心
Eureka Server既是一个注册中心,同时也是一个服务。那么搭建Eureka Server的方式和以往搭建Dubbo注册中心ZooKeeper的方式必然不同,那么首先搭建一个单机版的Eureka Server注册中心。
1 POM文件


2 配置文件application.yml
Eureka Server本身也是一个服务,同时又是一个注册中心。在Spring Cloud中,启动的微服务会自动的搜索注册中心并注册服务,那么在单机版Eureka Server环境中,当前服务注册到当前服务中,明显是不合适的。所以搭建Eureka Server单机版时,需要提供特殊的全局配置,避免回路注册逻辑。
同理,Eureka Server服务在注册中心中发现服务列表逻辑也是不必要的。毕竟注册中心是一个中立的服务管理平台,如果是单机版Eureka Server环境中,Eureka Server服务再去发现服务列表,明显也是不必要的。也需要通过全局配置,避免回路发现逻辑。


3 启动类


4 访问Eureka Server WEB服务管理平台
访问服务管理平台地址为: http://ip:port/
四、 Eureka 服务管理平台介绍
1 Eureka Server服务管理平台访问预览

2 System Status
系统状态展示
3 DS Replicas
注册中心集群列表
4 Instances currently registered with Eureka
已在注册中心中注册的服务列表
5 General Info
当前注册中心相关信息展示
6 Instance Info
当前注册中心实例信息展示
五、 搭建高可用集群
1 在Eureka应用中定义多环境配置
1.1 application-eureka1.yml

1.2 application-eureka2.yml


2 打包工程
2.1 POM依赖
增加Spring Boot打包插件


2.2 打包

2.3 打包结果

3 上传打包后的jar文件到Linux系统
4 设置Linux主机域名
修改/etc/hosts文件,设置主机域名。将主机域名和IP进行绑定。
vi /etc/hosts
新增内容如下:两个Linux系统修改内容相同。(IP根据具体环境配置)

5 启动Eureka
5.1 使用java命令启动
java -jar -Dspring.profiles.active=eureka1 cloudeureka-1.0-SNAPSHOT.jar
5.2 脚本启动
当然,每次通过命令来启动Eureka Server过于麻烦,可以定义一个shell文件来简化操作。(Java程序员不必要掌握shell脚本的编写。建议对shell脚本有一定的了解,至少能够修改内部的必要参数值。Shell脚本一般由运维或部署人员开发。也可能有系统工程师开发。)具体shell内容如下:










设置好shell启动脚本后,需要提供可执行权限:shell脚本文件名自己修改。
chmod 755 xxx.sh
脚本使用方式为:
启动Eureka Server命令: ./xxx.sh start
关闭Eureka Server命令: ./xxx.sh stop
六、 集群原理
Eureka Server注册中心的集群和Dubbo的ZooKeeper注册中心集群在结构上有很大的不同。
Eureka Server注册中心集群中每个节点都是平等的,集群中的所有节点同时对外提供服务的发现和注册等功能。同时集群中每个Eureka Server节点又是一个微服务,也就是说,每个节点都可以在集群中的其他节点上注册当前服务。又因为每个节点都是注册中心,所以节点之间又可以相互注册当前节点中已注册的服务,并发现其他节点中已注册的服务。
1 Eureka集群架构原理图

七、 Eureka优雅停服
1 自我保护模式
一般情况下,微服务在 Eureka 上注册后,会每 30 秒发送心跳包,Eureka 通过心跳来判断服务时候健康,同时会定期删除超过 90 秒没有发送心跳服务。
有两种情况会导致 Eureka Server 收不到微服务的心跳:一是微服务自身的原因;二是微服务与 Eureka 之间的网络故障。
通常微服务自身的故障关闭只会导致个别服务出现故障,一般不会出现大面积故障,而网络故障通常会导致 Eureka Server 在短时间内无法收到大批心跳。考虑到这个区别,Eureka 设置了一个阀值,当判断离线服务的数量超过阀值时,Eureka Server 认为很大程度上出现了网络故障,将不再删除心跳过期的服务。
那么这个阀值是多少呢?15分钟之内是否低于 85%;Eureka Server 在运行期间,会统计心跳失败的比例在15分钟内是否低于85%,这种算法叫做 Eureka Server 的自我保护模式。
1 为什么要自我保护
因为同时保留"好数据"与"坏数据"总比丢掉任何数据要更好,当网络故障恢复后,这个 Eureka 节点会退出"自我保护模式"。Eureka 还有客户端缓存功能(也就是微服务的缓存功能)。即便 Eureka 集群中所有节点都宕机失效,微服务的 Provider 和 Consumer都能依托服务缓存正常通信。微服务的负载均衡策略会自动剔除离线的微服务节点。
2 关闭自我保护
修改Eureka Server中的核心配置文件application.yml
