zoukankan      html  css  js  c++  java
  • Eureka如何剔除已经宕机的节点

     同一个服务部署了多个实例,在通过网关调用时会随机调用其中一个。但是,当某个服务挂掉之后,依然在注册中心中,依然会随机被调用到,调用时便会超时报错。(主要是开发测试或者演示时需要立即将失效的从注册中心剔除。)

    则:1、需要在注册中心,将eureka.server.eviction-interval-timer-in-ms改小,默认60秒,配置文件中单位是毫秒。

    eureka:
      instance:
        hostname: localhost
        # 过期时间,默认90s, 可不配置
        lease-expiration-duration-in-seconds: 90
        # 续约时间,默认30s,可不配置
        lease-renewal-interval-in-seconds: 30
        # ip地址优先
        prefer-ip-address: true
      server:
        # 关闭注册中心自我保护模式,避免注册中心不移除失效的服务,默认为true
        enable-self-preservation: true
        # 去除失效服务的时间间隔(毫秒)
        eviction-interval-timer-in-ms: 4000
      client:
        # 启用eureka客户端,默认为true, 可不配置
        enabled: true
        # 取注册信息,默认为true,可不配置
        fetchRegistry: false
        # 两个心跳参数,默认都是30s,可不配置
        instance-info-replication-interval-seconds: 30
        registry-fetch-interval-seconds: 30
        # 注册到注册中心,默认为true,可不配置
        registerWithEureka: false
        serviceUrl:
          defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

    2、还需要在业务微服务中,将过期时间默认90秒和续约时间默认30秒改小。

    eureka:
      client:
        serviceUrl:
          defaultZone: http://localhost:8761/eureka
      instance:
        instance-id: ${spring.cloud.client.ip-address}:${server.port}
        prefer-ip-address: true   #以IP地址注册到服务中心
        ip-address: 192.168.217.211
        non-secure-port: 8767
        #Eureka客户端向服务端发送心跳的时间间隔,单位为秒(客户端告诉服务端自己会按照该规则),默认30
        lease-renewal-interval-in-seconds: 10
        #Eureka服务端在收到最后一次心跳之后等待的时间上限,单位为秒,超过则剔除(客户端告诉服务端按照此规则等待自己),默认90
        lease-expiration-duration-in-seconds: 30

    注意:更改Eureka更新频率将打破服务器的自我保护功能

    其他几种主动下线服务的方式

    1. 直接停掉服务。

    默认情况下,如果Eureka Server在90秒没有收到Eureka客户的续约,它会将实例从其注册表中删除。但这种做法的不好之处在于, 客户端已经停止了运行,但仍然在注册中心的列表中。 虽然通过一定的负载均衡策略或使用熔断器可以让服务正常进行,但有没有方法让注册中心马上知道服务已经下线呢? 

    2.为了让注册中心马上知道服务要下线, 可以向eureka 注册中心发送delete 请求

    格式为 /eureka/apps/{application.name}/

    下面是下线一个hello-service的例子。 

    下图是用postman 发送delete请求

    值得注意的是,Eureka客户端每隔一段时间(默认30秒)会发送一次心跳到注册中心续约。如果通过这种方式下线了一个服务,而没有及时停掉的话,该服务很快又会回到服务列表中。

    所以,可以先停掉服务,再发送请求将其从列表中移除。

    3. 客户端主动通知注册中心下线 

    如果你的eureka客户端是是一个spring boot应用,可以通过调用以下代码通知注册中心下线。 

    DiscoveryManager.getInstance().shutdownComponent();

    例子如下,

    @RestController
    public class HelloController {
        @Autowired
        private DiscoveryClient client;
     
        @RequestMapping(value = "/hello", method = RequestMethod.GET)
        public String index() {
            java.util.List<ServiceInstance> instances = client.getInstances("hello-service");       
            return "Hello World";
        }
        
        @RequestMapping(value = "/offline", method = RequestMethod.GET)
        public void offLine(){
            DiscoveryManager.getInstance().shutdownComponent();
        }   
    }

    文章转载:https://blog.csdn.net/itwxming/article/details/91576288

    文章转载:https://blog.csdn.net/xiaobao5214/article/details/81263445

  • 相关阅读:
    扩展域并查集经典题
    2010提高组-C]关押罪犯(扩展域并查集
    [2015普及组-D]推销员 思维que
    The 2019 Asia Nanchang First Round Online Programming Contest C(cf原题,线段树维护矩阵)
    Fire-Fighting Hero(多源最短路和单源最短路)
    The Preliminary Contest for ICPC Asia Xuzhou 2019
    Cow Routing(最短路spfa)
    hdu6582
    ACM_题目这么难,来局愉快的昆特牌吧
    ACM_水题你信吗
  • 原文地址:https://www.cnblogs.com/zyulike/p/11821740.html
Copyright © 2011-2022 走看看