服务注册中心 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  关闭保护机制 

猜你喜欢

转载自www.cnblogs.com/qin1993/p/12566168.html