【229期】面试官——怎么解决Eureka某一个服务挂掉的问题?

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> 【229期】面试官——怎么解决Eureka某一个服务挂掉的问题?

【229期】面试官:怎么解决Eureka某一个服务挂掉的问题?

来源:cnblogs.com/zyulike/p/11821740.html

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

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.ListServiceInstance instances = client.getInstances("hello-service");       
        return "Hello World";
    }
    
    @RequestMapping(value = "/offline", method = RequestMethod.GET)
    public void offLine(){
        DiscoveryManager.getInstance().shutdownComponent();
    }   
}

END

十期推荐

与其在网上拼命找题?** 不如马上关注我们~**

【229期】面试官:怎么解决Eureka某一个服务挂掉的问题?

原文始发于微信公众号(Java面试题精选):

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> 【229期】面试官——怎么解决Eureka某一个服务挂掉的问题?


 上一篇
【228期】面试高频——Java常用的八大排序算法一网打尽! 【228期】面试高频——Java常用的八大排序算法一网打尽!
来源:jianshu.com/p/5e171281a387 1.直接插入排序 经常碰到这样一类排序问题:把新的数据插入到已经排好的数据列中。 将第一个数和第二个数排序,然后构成一个有序序列 将第三个数插
2021-04-05
下一篇 
【230期】面试官——讲讲Bean的加载过程 【230期】面试官——讲讲Bean的加载过程
来源:cnblogs.com/wyq178/p/11415877.html spring作为目前我们开发的基础框架,每天的开发工作基本和他形影不离,作为管理bean的最经典、优秀的框架,它的复杂程度往往令人
2021-04-05