• 服务注册中心 Eureka


    ------------恢复内容开始------------

    Eureka是Netflix开发的服务发现框架,SpringCloud将它集成在自己的子项目spring-cloud-netflix中,实现SpringCloud的服务发现功能。Eureka包含两个组件:Eureka Server和Eureka Client。
    Eureka Server提供服务注册服务,各个节点启动后,会在Eureka Server中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到。
    Eureka Client是一个java客户端,用于简化与Eureka Server的交互,客户端同时也就别一个内置的、使用轮询(round-robin)负载算法的负载均衡器。在应用启动后,将会向Eureka Server发送心跳,默认周期为30秒,如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,Eureka Server将会从服务注册表中把这个服务节点移除(默认90
    秒)
    Eureka Server之间通过复制的方式完成数据的同步,Eureka还提供了客户端缓存机制,即使所有的Eureka Server都挂掉,客户端依然可以利用缓存中的信息消费其他服务的API。综上,Eureka通过心跳检查、客户端缓存等机制,确保了系统的高可用性、灵活
    性和可伸缩性。
     
    引入依赖 父工程pom.xml定义SpringCloud版本
    <dependencyManagement> 
      <dependencies> 
        <dependency>
         <groupId>org.springframework.cloud</groupId>
    <artifactId>spring‐cloud‐dependencies</artifactId>
    <version>Finchley.M9</version>       <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
    服务端   
     
    引入eurek
    <dependencies> 
    <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring‐cloud‐starter‐netflix‐eureka‐ server</artifactId>
    </dependency>
    </dependencies>

    appliction.yml

    server: 
      port: 6868 #服务端口 
    eureka: 
      client: 
        registerWithEureka:
    false #是否将自己注册到Eureka服务中,本身就是所有无需 注册     fetchRegistry: false #是否从Eureka中获取注册信息     serviceUrl: #Eureka客户端与Eureka服务端进行交互的地址       defaultZone: http://127.0.0.1:${server.port}/eureka/
    server:
    eviction-interval-timer-in-ms: 0 //设置清理无效节点的时间间隔(单位:毫秒)

     启动类    @EnableEurekaServer

    @SpringBootApplication 
    @EnableEurekaServer
    public class EurekaServer {

      public static void main(String[] args) {
        SpringApplication.run(EurekaServer.class, args);
    }
    }

    客户端 

       引入依赖

    <dependency> 
      <groupId>org.springframework.cloud</groupId>
    <artifactId>spring‐cloud‐starter‐netflix‐eureka‐ client</artifactId>
    </dependency>

    application.yml 配置 

    eureka: 
        client:
             service‐url: defaultZone: http://localhost:6868/eureka   
              registry-fetch-interval-seconds :30  //拉取服务注册信息时间 秒  默认30
      instance:
    eureka.instance.instance-id:xxx //示例id prefer‐ip‐address:
    true //显示ip
    lease-renewal-interval-in-seconds: 30 //默认30 30s后没有收到心跳,将摘除改实例。
      lease-expiration-duration-in-seconds:90 //默认90 设置过期剔除时间(单位秒) 表示eureka server至上一次收到client的心跳之后,等待下一次心跳的超时时间。

                                                               如果该值太大,则很可能将流量转发过去的时候,该instance已经不存活了。

                                                               如果该值设置太小了,则instance则很可能因为临时的网络抖动而被摘除掉。

                                                                该值至少应该大于leaseRenewalIntervalInSeconds。

    启动类 
    @EnableEurekaClient

    保护机制 

    Eureka Server在运行期间,会统计心跳失败的比例在15分钟之内是否低于85%,如果出现低于的情况(在单机调试的时候很容易满足,实际在生产环境上通常是由于网络不稳定导致),Eureka Server会将当前的实例注册信息保护起来,同时提示这个警告。保护模式主要用于一组客户端和Eureka Server之间存在网络分区场景下的保护。一旦进入保护模式,Eureka Server将会尝试保护其服务注册表中的信息,不再删除服务注册表中的数据(也就是不会注销任何微服务)。
     
    单机测试时 
     eureka.server.enable-self-preservation=false  关闭保护机制 
  • 相关阅读:
    【网络】【操作系统】select、poll、epoll
    【JMM】java内存模型及volatile关键字底层
    【数据库】连接查询(from 内连接 外连接)
    【数据库】SQL牛客练习关键点复习
    【SpringMVC】文件/图片 的下载与上传
    【SpringMVC】拦截器实现与网页跳转步骤
    什么是hashMap,初始长度,高并发死锁,java8 hashMap做的性能提升
    自己写一个HashMap
    String去除重复字符两个方法
    Solr与Elasticsearch比较
  • 原文地址:https://www.cnblogs.com/qin1993/p/12566168.html
Copyright © 2020-2023  润新知