`

跟我学Spring Cloud(Finchley版)-06-服务注册与服务发现-Eureka深入

 
阅读更多

说明:SpringCloud系列笔者自学系列,学习来源是周立的博客  http://www.itmuch.com/ 。而此处转载其博客只是为了方便自己以后的学习。

本篇来源 http://www.itmuch.com/spring-cloud/finchley-6/

 

跟我学Spring Cloud(Finchley版)-05-服务注册与服务发现-Eureka入门 一节中,已经编写了一个Eureka Server,并将服务提供者与消费者都注册到了Eureka Server上。

 

本节,来深入探讨Eureka的高级特性。

 

Eureka原理

 

本节来探讨Eureka的原理。

 

Region & Availability Zone

 

下面分析一下Eureka原理,在分析原理前,先来了解一下Region和Availability Zone,如下图。

 

图-Region And Availibility Zone

 

众所周知,Netflix公司将他们的应用都部署在了AWS上,所以Eureka的架构使用到了AWS中的一些概念——不用担心,这不是说Eureka和AWS环境绑定,Eureka可以部署在任意环境

 

Region和Availability Zone均是AWS的概念。

 

  • Region表示AWS中的地理位置,例如us-east-1、us-east-2、eu-west-1等;
  • 每个Region都有多个Availability Zone,彼此内网打通
  • 各个Region之间完全隔离,彼此内网不打通
  • AWS通过这种方式实现了最大的容错和稳定性。

 

Spring Cloud中,默认使用的Region是us-east-1 。非AWS环境下,可将将Region理解为内网没有打通的机房,将Availability Zone理解成相同机房的不同机架(内网打通)。

 

拓展阅读

 

 

Eureka架构详解

 

Eureka架构

 

如图是Eureka集群的工作原理。图中的组件非常多,概念也比较抽象,我们先来用通俗易懂的文字翻译一下:

 

  • Application Service:服务提供者;

  • Application Client:服务消费者;

  • Make Remote Call调用RESTful API;

  • us-east-1c、us-east-1d等都是Availability Zone,它们都属于us-east-1这个region。

 

由图可知,Eureka包含两个组件:Eureka Server 和 Eureka Client,它们的作用如下:

 

  • Eureka Server提供服务发现的能力,各个微服务启动时,会向Eureka Server注册自己的信息(例如IP、端口、微服务名称等),Eureka Server会存储这些信息;

  • Eureka Client是一个Java客户端,用于简化与Eureka Server的交互;

  • 微服务启动后,会周期性(默认30秒)地向Eureka Server发送心跳以续约自己的“租期”;

  • 如果Eureka Server在一定时间内没有接收到某个微服务实例的心跳,Eureka Server将会注销该实例(默认90秒);

  • 默认情况下,Eureka Server同时也是Eureka Client。多个Eureka Server实例,互相之间通过增量复制的方式,来实现服务注册表中数据的同步。Eureka Server默认保证在90秒内,Eureka Server集群内的所有实例中的数据达到一致(从这个架构来看,Eureka Server所有实例所处的角色都是对等的,没有类似Zookeeper、Consul、Etcd等软件的选举过程,也不存在主从,所有的节点都是主节点。Eureka官方将Eureka Server集群中的所有实例称为“对等体(peer)”)

  • Eureka Client会缓存服务注册表中的信息。这种方式有一定的优势——首先,微服务无需每次请求都查询Eureka Server,从而降低了Eureka Server的压力;其次,即使Eureka Server所有节点都宕掉,服务消费者依然可以使用缓存中的信息找到服务提供者并完成调用。

 

综上,Eureka通过心跳检查、客户端缓存等机制,提高了系统的灵活性、可伸缩性和可用性。

 

TIPS

 

事实上,这个官方架构图是有一点问题的:Eureka Server本身也集成了Eureka Client,彼此通过Eureka Client同步数据给其它实例又或者从其他实例同步数据——现在,你应该能理解上一节中所使用的 register-with-eureka 以及fetch-registry 的作用了。

 

高可用

 

编写高可用Eureka Server

 

下面来编写一个双节点Eureka Server集群。编写这个集群非常简单,只需修改单实例Eureka Server的配置即可:

 

  • 为系统配置主机名:

     
    vim /etc/hosts
    # 添加如下内容
    127.0.0.1 peer1 peer2
    
    对于Windows系统,请修改C:\windows\system32\drivers\etc\hosts文件
  • 配置:

     
    spring:
      application:
        name: microservice-discovery-eureka-ha
    ---
    spring:
      profiles: peer1                                 # 指定profile=peer1
    server:
      port: 8761
    eureka:
      instance:
        hostname: peer1                               # 指定当profile=peer1时,主机名是peer1
      client:
        serviceUrl:
          defaultZone: http://peer2:8762/eureka/      # 将自己注册到peer2这个Eureka上面去
    ---
    spring:
      profiles: peer2
    server:
      port: 8762
    eureka:
      instance:
        hostname: peer2
      client:
        serviceUrl:
          defaultZone: http://peer1:8761/eureka/

    由配置不难看出我们设置了两个Profile:peer1、peer2。两个Profile下各有一个Eureka Server,通过相互注册的方式,构建了Eureka Server集群。

  • 启动:

     
    java -jar microservice-discovery-eureka-ha-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1
    java -jar microservice-discovery-eureka-ha-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2

    第一个实例会报错,这是正常的,因为它会尝试连接第二个实例,但第二个实例尚未启动,所以会报连接不上的异常。

 

注意点

 

  • 如果两个Eureka Server实例在同一台机器上启动,那么配置hosts的这一步不能少。原因:Eureka Server对端口是不敏感的,这意味着,如果直接用IP的形式(例如地址写成http://127.0.0.1:8761/eureka/)相互注册,Eureka Server误认为两个Eureka Server实例是一个实例——这会造成Eureka Server首页显示不正常等一系列问题!!

 

拓展阅读

 

 

TIPS

 

编写Eureka Server集群的简写方式:

 

 
spring:
  application:
    name: microservice-discovery-eureka-ha
eureka:
  client:
    serviceUrl:
      defaultZone: http://peer2:8762/eureka/,http://peer1:8761/eureka/
---
spring:
  profiles: peer1
server:
  port: 8761
eureka:
  instance:
    hostname: peer1
---
spring:
  profiles: peer2
server:
  port: 8762
eureka:
  instance:
    hostname: peer2

 

将应用注册到Eureka Server集群上

 

microservice-provider-user 项目为例,只须修改eureka.client.serviceUrl.defaultZone,配置多个Eureka Server地址,就可以将其注册到Eureka Server集群了。示例:

 

 
eureka:
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/,http://peer2:8762/eureka/

 

这样就可以将服务注册到Eureka Server集群上了。

 

当然,微服务即使只配置Eureka Server集群中的某个节点,也能正常注册到Eureka Server集群,因为多个Eureka Server之间的数据会相互同步。例如:

 

 
eureka:
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/

 

正常情况下,这种方式与配置多个Server节点的效果是一样的。不过为适应某些极端场景,笔者建议在客户端配置多个Eureka Server节点。

 

应用启动后,访问Eureka Server应能看到类似如下的界面:

 

Eureka集群首页

 

RESTful API

 

前文说过,Eureka本身是一个基于REST的服务。本节来探讨Eureka Server的RESTful API。

 

下表展示了Eureka Server提供的RESTful API,来自https://github.com/Netflix/eureka/wiki/Eureka-REST-operations ,只需按表格向Eureka Server发送请求,即可操作Eureka Server中的数据。

 

OperationHTTP actionDescription
Register new application instance POST /eureka/apps/appID Input:JSON/XMLpayload HTTPCode: 204 on success
De-register application instance DELETE /eureka/apps/appID/instanceID HTTP Code: 200 on success
Send application instance heartbeat PUT /eureka/apps/appID/instanceID HTTP Code: 200 on success 404 if instanceID doesn’t exist
Query for all instances GET /eureka/apps HTTP Code: 200 on success Output:JSON/XML
Query for all appIDinstances GET /eureka/apps/appID HTTP Code: 200 on success Output:JSON/XML
Query for a specificappID/instanceID GET /eureka/apps/appID/instanceID HTTP Code: 200 on success Output:JSON/XML
Query for a specificinstanceID GET /eureka/instances/instanceID HTTP Code: 200 on success Output:JSON/XML
Take instance out of service PUT /eureka/apps/appID/instanceID/status?value=OUT_OF_SERVICE HTTP Code: 200 on success 500 on failure
Put instance back into service (remove override) DELETE /eureka/apps/appID/instanceID/status?value=UP (The value=UP is optional, it is used as a suggestion for the fallback status due to removal of the override) HTTP Code: 200 on success 500 on failure
Update metadata PUT /eureka/apps/appID/instanceID/metadata?key=value HTTP Code: 200 on success 500 on failure
Query for all instances under a particular vip address GET /eureka/vips/vipAddress HTTP Code: 200 on success Output:JSON/XML 404 if thevipAddressdoes not exist.
Query for all instances under a particular secure vip address GET /eureka/svips/svipAddress HTTP Code: 200 on success Output:JSON/XML 404 if thesvipAddressdoes not exist.

 

调用示例

 

示例1:注册一个服务:

 

  • 将以下文件存储为rest-api-test.xml

     
    <instance>
      <instanceId>itmuch:rest-api-test:9000</instanceId>
      <hostName>itmuch</hostName>
      <app>REST-API-TEST</app>
      <ipAddr>127.0.0.1</ipAddr>
      <vipAddress>rest-api-test</vipAddress>
      <secureVipAddress>rest-api-test</secureVipAddress>
      <status>UP</status>
      <port enabled="true">9000</port>
      <securePort enabled="false">443</securePort>
      <homePageUrl>http://127.0.0.1:9000/</homePageUrl>
      <statusPageUrl>http://127.0.0.1:9000/info</statusPageUrl>
      <healthCheckUrl>http://127.0.0.1:9000/health</healthCheckUrl>
      <dataCenterInfo class="com.netflix.appinfo.InstanceInfo$DefaultDataCenterInfo">
        <name>MyOwn</name>
      </dataCenterInfo>
    </instance>
  • 通过cURL调用Eureka Server

     
    cat ./rest-api-test.xml | curl -v -X POST -H "Content-type: application/xml" -d @- http://localhost:8761/eureka/apps/rest-api-test

 

示例2:查看指定服务的所注册的信息

 

只需访问:http://Eureka Server的地址/eureka/apps/microservice-provider-user 即可查看microdervice-provider-user 服务的信息。

 

RESTful API的意义

 

你可能会问:我们不是已经有Eureka Client了吗?谁闲着没事再去用RESTful API啊?

 

要知道,微服务的优势之一就是允许使用异构的技术、异构的语言甚至异构的平台解决你想解决的问题。

 

举个例子,如果你有一个系统,一部分是Spring Cloud构建的,一部分是用世界上最好的语言PHP写的!但是呢,你希望Java应用与PHP应用之间的通信也能享受服务发现所带来的好处,此时就可编写一个基于PHP的Eureka Client,将PHP应用也注册到Eureka Server!

 

事实上,前文说的Eureka Client不过是一个用Jersey 1.x封装了RESTful API的Jar包而已

 

拓展阅读
事实上,业界已经有一些不同语言的Eureka Client,例如:

 

 

自我保护模式

 

自我保护模式是Eureka的重要特性,笔者之前已经专题写过文章详解了,所以本系列不再赘述,详见:理解Eureka的自我保护模式

 

用户认证

 

Finchley版本相对之前的版本有些改动,比较重要。详见: 跟我学Spring Cloud(Finchley版)番外-01-Eureka安全详解 

 

配套代码

 

 

相关文章

 

 

分享到:
评论

相关推荐

    springcloud-Netflix-eureka demo 可做参考

    本项目"springcloud-Netflix-eureka demo"提供了一个基于Spring Boot搭建的基础服务框架,旨在帮助开发者理解和学习如何使用Eureka进行服务注册与发现,以及Ribbon客户端负载均衡。 首先,我们来看Eureka。Eureka是...

    spring-cloud-starter-netflix-eureka-server-1.4.5.RELEASE.jar

    spring-cloud-starter-netflix-eureka-server-1.4.5.RELEASE.jar

    springcloud-eureka-server.zip

    在分布式微服务架构中,服务治理扮演着至关重要的角色,而SpringCloud Eureka Server正是这样一款专为解决服务注册与发现问题而设计的组件。本文将围绕"springcloud-eureka-server.zip"这个项目,深入探讨Spring...

    spring-cloud-starter-eureka-server-1.4.5.RELEASE.jar

    spring-cloud-starter-eureka-server-1.4.5.RELEASE.jar

    spring cloud eureka(免费下载)

    - 添加必要的依赖,包括`spring-cloud-starter-netflix-eureka-server`,这是Eureka服务注册中心的核心依赖,以及`spring-boot-starter-test`用于测试。 - 在`pom.xml`文件中,设置`spring-cloud.version`属性为`...

    Spring Cloud Eureka Server

    Spring Cloud Eureka Server是Spring Cloud框架中的一个关键组件,它主要负责服务的注册与发现,是微服务架构中实现服务治理的重要工具。Eureka Server作为服务注册中心,为其他微服务提供服务注册和发现的能力,...

    springcloud-eureka-feign-mybatis-seata.zip

    首先,Spring Cloud Eureka是Netflix公司提供的一个服务注册与发现组件,它允许微服务实例向Eureka Server注册自身,同时也允许客户端通过Eureka Server找到其他服务实例。Eureka提供了高可用的服务注册中心,确保...

    spring-cloud-netflix-eureka-server-2.0.4.RELEASE.jar

    Eureka修改增加页面操作,用于多人开发测试操作流程。可以更好的进行协调操作,只需要替换本地仓库的jar包就行

    SpringCloud-服务注册与实现-Eureka创建服务提供者示例源码.zip

    总的来说,Eureka是Spring Cloud中的关键组件,它的服务注册与发现机制简化了微服务之间的通信,降低了系统的复杂性。通过学习和实践这个Eureka服务提供者示例,开发者能够深入理解Eureka的工作原理,并将其应用到...

    Spring Cloud Finchley SR2全套(集成Spring Gateway)

    ├──cloud-eureka-server──────────────服务注册中心[8761] ├──cloud-turbine-server─────────────断路器聚合监控[8769] ├──cloud-zipkin-server──────────────...

    spring-cloud-eureka 服务注册及发现实例

    在这个实例中,我们将探讨如何利用 Spring Cloud Eureka 实现服务注册与发现,以及相关的配置和实践。 首先,Spring Boot 是一个快速开发框架,它简化了创建独立、生产级别的基于 Spring 的应用程序。版本 2.1.10....

    spring-cloud-netflix-eureka-server-1.4.5.RELEASE.jar

    spring-cloud-netflix-eureka-server-1.4.5.RELEASE.jar

    SpringCloud-2.0-eureka-service-10000.zip

    在微服务架构中,服务发现是至关重要的一个环节,SpringCloud作为主流的微服务框架,提供了丰富的组件来支持这一功能,其中Eureka便是用于服务注册与发现的核心组件。本文将深入探讨SpringCloud 2.0版本下Eureka服务...

    springcloud-learning-master.zip

    1. **Eureka**:Eureka是Spring Cloud Netflix项目的一部分,用于实现服务注册与发现。服务启动后会自动向Eureka Server注册,其他服务可以通过Eureka Server查找并消费这些服务。Eureka通过心跳机制来监控服务的...

    spring-cloud-examples

    spring-cloud-config-eureka-bus:配置中心和消息总线示例(配置中心终结版) gateway-service-zuul:Spring Cloud Zuul使用初级篇 网关 均衡负载 spring-cloud-zuul:Spring Cloud Zuul使用高级篇 Filter 鉴权 熔断...

    springcloud-learning-master.zip springcloud学习合集

    1. **Eureka**:服务注册与发现。Eureka是Netflix开源的服务注册和发现组件,每个微服务启动后,都会向Eureka Server注册自己的信息,消费者通过Eureka Server获取服务提供者的信息,实现服务之间的调用。 2. **...

    spring-cloud-netflix-hystrix应用

    《深入理解Spring Cloud Netflix Hystrix:构建弹性微服务...在实际项目中,结合Spring Cloud其他组件,如Eureka(服务发现)、Zuul(API网关)等,可以构建出更为完善的微服务体系,提升整体系统的稳定性和可维护性。

    springcloud-provider-consumer-eureka

    本项目“springcloud-provider-consumer-eureka”旨在提供一个基础的SpringCloud入门示例,涵盖了一个简单的用户服务提供者(Provider)和一个电影服务消费者(Consumer),以及对服务注册与发现组件Eureka的初步...

    spring-cloud-demo-master.zip

    Eureka是Spring Cloud中的核心组件,它提供服务注册与发现的功能。在"spring-cloud-demo-master"项目中,Eureka作为服务治理的中心,负责维护各个服务实例的信息。服务启动后,会向Eureka Server注册自身,其他服务...

Global site tag (gtag.js) - Google Analytics