zoukankan      html  css  js  c++  java
  • SpringCloud-微服务的注册与发现Eureka

    一、SpringCloud简介

      Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。Spring Cloud并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。

    二、微服务的注册与发现-Eureka

      Eureka是Netflix开源的服务发现组件,本身是基于Rest的服务,它包含服务端和客户端两部分;在SpringCloud中将它集成在其中,从而实现了微服务的发现与注册;
    - Eureka的GitHub:https://github.com/Netflix/Eureka
      


    Eureka Server
    - 服务端-没有存储,内存保持,每服务实例需要发送心跳去续约
    - 客户端-在内存中缓存着eureka的注册信息,因此不必每请求到eureka查找服务
    - eureka之间会做注册服务同步,从而保证状态一致,客户端只需访问一个eureka
    Service Provider
    - 会向Eureka Server做Register(服务注册)、Renew(服务续约)、Cancel(服务下线)等操作
    Service Consumer
    - 会向Eureka Server获取注册服务列表,并消费服务

    三、简单实战

    1、编写服务端(SpringCloud使用的是Edgware SR3版本)


    在pom.xml中加入以下依赖:

    复制代码
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.13.RELEASE</version>
      </parent>
    

    <dependencies>
    <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-eureka-server</artifactId>
    </dependency>
    </dependencies>
    <dependencyManagement>
    <dependencies>
    <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-dependencies</artifactId>
    <version>Edgware.SR3</version>
    <type>pom</type>
    <scope>import</scope>
    </dependency>
    </dependencies>
    </dependencyManagement>

    复制代码

    在配置文件application.xml中添加以下配置:

    复制代码
    server.port=8781
    #表示是否将自己注册在EurekaServer上,默认为true。由于当前应用就是EurekaServer,所以置为false
    eureka.client.register-with-eureka=false
    #表示表示是否从EurekaServer获取注册信息,默认为true。单节点不需要同步其他的EurekaServer节点的数据
    eureka.client.fetch-registry=false
    #设置Eureka的地址
    eureka.client.service-url.defaultZone=http://localhost:8781/eureka
    复制代码

    添加启动类,并加上启动Eureka注解:

    复制代码
    @SpringBootApplication
    @EnableEurekaServer
    public class Application {
    
    </span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">static</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> main(String[] args) {
        SpringApplication.run(Application.</span><span style="color: #0000ff;">class</span><span style="color: #000000;">, args);
    }
    

    }

    复制代码

    启动项目,打开http://localhost:8781/,如下:

    2、编写客户端(SpringCloud使用的版本与服务端一致)


     在pom.xml中加入依赖:

    复制代码
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-parent</artifactId>
        <version>1.5.13.RELEASE</version>
      </parent>
    

    <dependencies>
    <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-eureka</artifactId>
    </dependency>
    </dependencies>
    <dependencyManagement>
    <dependencies>
    <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-dependencies</artifactId>
    <version>Edgware.SR3</version>
    <type>pom</type>
    <scope>import</scope>
    </dependency>
    </dependencies>
    </dependencyManagement>

    复制代码

    在配置文件application.xml加入要注入的配置中心的url等配置:

    server.port=8782
    #对该应用另起别名
    spring.application.name=client-8782
    #注入目标,配置服务中心url,与服务端的配置保持一致
    eureka.client.service-url.defaultZone=http://localhost:8781/eureka/

    创建客户端启动类ClientApplication.java,并加入客户端被发现注解:

    复制代码
    @SpringBootApplication
    @EnableDiscoveryClient
    public class ClientApplication {
    
    </span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">static</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> main(String[] args) {
        SpringApplication.run(ClientApplication.</span><span style="color: #0000ff;">class</span><span style="color: #000000;">, args);
    }
    

    }

    复制代码

    启动应用,接着打开之前Eureka的注册页面http://localhost:8781/,如下:

    发现刚刚启动的客户端已经注册在了服务端了。

    当我将客户端关闭后,再次打开Eureka的注册页面,发现有一串红字:

    EMERGENCY! EUREKA MAY BE INCORRECTLY CLAIMING INSTANCES ARE UP WHEN THEY'RE NOT. RENEWALS ARE LESSER THAN THRESHOLD AND HENCE THE INSTANCES ARE NOT BEING EXPIRED JUST TO BE SAFE.

    这是因为Eureka进入了自我保护机制,默认情况下,如果EurekaServer在一定时间内没有接收到某个微服务实例的心跳时,EurekaServer将会注销该实例(默认90s)。但是当网络发生故障时,微服务与EurekaServer之间无法通信,这样就会很危险了,因为微服务本身是很健康的,此时就不应该注销这个微服务,而Eureka通过自我保护机制来预防这种情况,当网络健康后,该EurekaServer节点就会自动退出自我保护模式;

    这时再次将客户端微服务启动,刷新服务注册中心会发现,自我保护状态已取消。

    综上所述,我们可以看出来Eureka的两个组件EurekaServer和EurekaClient的作用:

    1. EurekaServer 提供服务发现的能力,各个微服务启动时,会向EurekaServer注册自己的信息(例如:ip、端口、微服务名称等),EurekaServer会存储这些信息;
    2. EurekaClient是一个Java客户端,用于简化与EurekaServer的交互;
    3. 微服务启东后,会定期性(默认30s)的向EurekaServer发送心跳以续约自己的“租期”;
    4. 如果EurekaServer在一定时间内未接收某个微服务实例的心跳,EurekaServer将会注销该实例(默认90s);
    5. 默认情况下,EurekaServer同时也是EurekaClient。多个EurekaServer实例,互相之间通过复制的方式,来实现服务注册表中数据的同步;
    6. EurekaClient也会缓存服务注册表中的信息;

    综上,Eureka通过心跳检查、客户端缓存等机制,提高了系统的灵活性、可伸缩性和可用性,所以作为一个微服务架构,需要一个服务注册中心来统筹管理服务;

    3、Eureka高可用


     复制上面server项目,分别命名:eureka-keepalived-server-1,eureka-keepalived-server2;

     复制上面client项目,命名为:eureka-keepalived-client;

    修改hosts文件:

    127.0.0.1    localhost server1 server2

    修改application.properties配置文件(注意需要将eureka.client.register-with-eureka、eureka.client.fetch-registry注释掉):

    eureka-keepalived-server-1的配置文件:

    复制代码
    server.port=8781
    spring.application.name=eureka-server-1
    spring.profiles.active=server1
    #eureka.client.register-with-eureka=false
    #eureka.client.fetch-registry=false
    #指定主机名
    eureka.instance.hostname=server1
    #设置EurekaServer的地址,将自身注册到Server2
    eureka.client.service-url.defaultZone=http://server2:8782/eureka
    复制代码

    eureka-keepalived-server-2的配置文件:

    复制代码
    server.port=8782
    spring.application.name=eureka-server-2
    #指定hostname
    spring.profiles.active=server2
    #eureka.client.register-with-eureka=false
    #eureka.client.fetch-registry=false
    #指定主机名
    eureka.instance.hostname=server2
    #设置EurekaServer的地址,将自己注册在Server2上
    eureka.client.service-url.defaultZone=http://server1:8781/eureka
    复制代码

    eureka-keepalived-client的配置文件:

    复制代码
    server.port=8783
    #对该应用另起别名
    spring.application.name=client-8783
    #注入目标,配置服务中心url,与服务端的配置保持一致,这里可以写多个,以“,”分隔,如http://server1:8781/eureka/,http://server2:8782/eureka/
    eureka.client.service-url.defaultZone=http://server1:8781/eureka/
    复制代码

    分别启动两个服务端server2、server1,访问,server1:8781/,server2:8782/,如下:

    启动客户端,发现客户端分别在两个服务端都有相应的注册,而我们的客户端实际只指定了一个Server;

    至此,完成了Eureka的高可用;

    示例代码:https://gitee.com/lfalex/springcloud-example.git

    参考书籍:《SpringCloud与Docker微服务架构实战》周力著

  • 相关阅读:
    mysql调优
    面试、。。。。
    StringBuffer 和 StringBuilder 的 3 个区别
    msql查询指定日期
    Windows 路由跟踪
    Xdebug配置
    ONVIF流媒体播放流程
    Windows 8 SP1 安装StockTrader 6.1
    使用log4c问题
    xcode插件安装
  • 原文地址:https://www.cnblogs.com/jpfss/p/11281850.html
Copyright © 2011-2022 走看看