如何剔除eureka无效和down状态的问题

 更新时间:2023年07月10日 09:30:37   作者:岸河  
这篇文章主要介绍了如何剔除eureka无效和down状态的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

如何剔除eureka无效和down状态

在eureka server的web界面上

我们经常看见有的实例明明被我们关掉了,但是仍然展示在服务实例的列表里面,而且状态还是UP?

这种情况是eureka的自我保护机制导致的。由于eureka和实例之间要进行心跳检测,但是当网络故障时,eureka server不能准确判断这个实例时存活还是死亡,于是采取的默认策略是认为其任然存活。

这是eureka的AP思想(Availability-可用性,Partition-分区容错性)的体现,给予实例存活的状态。

当然我们也可以通过如下配置,来关掉eureka的自我保护机制(仅限开发环境),这样一旦接收不到实例心跳,就将其剔除。

eureka.server.enable-self-preservation=false

但是生产环境是不能使用这种配置的,否则网络状况一不稳定,就将本来是健康的实例剔除掉,会大大降低服务的可用性。

备注:有的文章说造成这种现象的原因是我们的服务没有正常关闭,IDEA中我们直接Stop服务会导致这种状况,如果选择Exit就不会出现这种情况。我还没有验证。

对于一些已经DOWN掉的节点

想直接剔除掉,不想让他展示在界面中?

这个问题和上个问题的解决办法是一致的,如下。

解决办法:

使用Postman发送delete请求,主动删除无效实例。

如图,我们构建上述DELETE请求

DELETE请求
http://localhost:8761/eureka/apps/ABC-BOOT/192.168.1.50:abc-boot:9020
# 格式
http://注册中心地址/eureka/apps/实例名称/节点详细信息

1.注意要使用DELETE请求;

2.注意JESSIONID可以从eureka界面的F12中获取,否则会验证失败。

eureka自动剔除无效的服务

由于Eureka拥有自我保护机制,当其注册表里服务因为网络或其他原因出现故障而关停时,Eureka不会剔除服务注册,而是等待其修复。这是AP的一种实现。

若要剔除无效服务,可以按照以下方式实现

在eureka注册服务中心上配置

server端配置:

eureka:
    server:
        enable-self-preservation: false
        eviction-interval-timer-in-ms: 4000
  • enable-self-preservation: 关闭自我保护模式(缺省为打开)
  • eviction-interval-timer-in-ms: 续期时间,即扫描失效服务的间隔时间

在eureka client节点上配置

client配置:

eureka:
    instance:
        lease-renewal-interval-in-seconds: 10
        lease-expiration-duration-in-seconds: 30
  • lease-renewal-interval-in-seconds:表示eureka client发送心跳给server端的频率
  • lease-expiration-duration-in-seconds: 发呆时间,即服务续约到期时间

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 基于Java实现QQ邮箱发送工具类

    基于Java实现QQ邮箱发送工具类

    我们在日常开发中,需要实现一个对邮箱的发送,今天就实现邮箱的发送工具类,只需要一些注册邮箱之后的配置即可,感兴趣的小伙伴可以了解下
    2023-12-12
  • Spring IoC学习之ApplicationContext中refresh过程详解

    Spring IoC学习之ApplicationContext中refresh过程详解

    这篇文章主要给大家介绍了关于Spring IoC学习之ApplicationContext中refresh过程的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Java集合和数组的区别

    Java集合和数组的区别

    本文主要介绍了Java集合和数组的区别。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • Java中final修饰的方法是否可以被重写示例详解

    Java中final修饰的方法是否可以被重写示例详解

    这篇文章主要给大家介绍了关于Java中final修饰的方法是否可以被重写的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Spring中的@Pointcut切点详解

    Spring中的@Pointcut切点详解

    这篇文章主要介绍了Spring中的@Pointcut切点详解,pointcut就是切点,通知需要在哪些方法处进行增强,在AspectJ中用@Pointcut注解表达式标注,需要的朋友可以参考下
    2023-08-08
  • MybatisPlus中QueryWrapper常用方法总结

    MybatisPlus中QueryWrapper常用方法总结

    MyBatis-Plus是一个Mybatis增强版工具,在MyBatis上扩充了其他功能没有改变其基本功能,为了简化开发提交效率而存在,queryWrapper是mybatis plus中实现查询的对象封装操作类,本文就给大家总结了MybatisPlus中QueryWrapper的常用方法,需要的朋友可以参考下
    2023-07-07
  • mybatis typeAliases 给实体类起别名的方法

    mybatis typeAliases 给实体类起别名的方法

    这篇文章主要介绍了mybatis typeAliases 给实体类起别名,本文给大家分享两种用法,通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • Java Validation方法入参校验实现过程解析

    Java Validation方法入参校验实现过程解析

    这篇文章主要介绍了Java Validation方法入参校验实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • 使用Feign远程调用时,序列化对象失败的解决

    使用Feign远程调用时,序列化对象失败的解决

    这篇文章主要介绍了使用Feign远程调用时,序列化对象失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Java中如何比较两个数组中元素是否相同

    Java中如何比较两个数组中元素是否相同

    比较两个数组中的元素是否相同,在项目中经常会使用到,下面与大家分享个最简单的方法
    2014-06-06

最新评论