Eureka对异常下线实例踢出的bug

最近在做eureka参数调优,发现了个eureka踢出异常下线实例的bug,测试的时候发现,当实例异常下线时,eureka踢出实例的时间基本都是 “超时踢出秒数的2倍 + 补偿时间(lease-expiration-duration-in-seconds: 8 #超时8秒剔除)”。 看了下源码发现是eureka存在的一个小bug,eureka的续约renew = System.currentTimeMillis() + duration(踢出时长);续约的时候错误的多加了个duration,导致在计算超时的时候也多加了个duration,所以实际计算踢出时间等于加了两次的 duration,所以异常实例的剔除变成了 “超时踢出秒数的2倍 + 补偿时间”,看注释是作者认为修复的话影响较大,而且这个bug只影响异常下线的实例,不修复了。还是得注意下啊
!Eureka对异常下线实例踢出的bug在这里插入图片描述
Eureka对异常下线实例踢出的bugEureka对异常下线实例踢出的bug