环境描述
两个eureka服务 peer1,peer2 为了提高HA
peer1:http://IP1:8761/eureka/
peer2:http://IP2:8761/eureka/
peer1 配置信息
server.port=8761
logging.level.* = debug
logging.file=/pathxxx/eureka-peer1.log
# 是否注册到eureka
#eureka.client.register-with-eureka=true
# 是否从eureka获取注册信息
#eureka.client.fetch-registry=false
spring.application.name=eureka-server
eureka.instance.hostname=peer1
# eureka服务器的地址(注意:地址最后面的 /eureka/ 这个是固定值)
#eureka.client.serviceUrl.defaultZone=http://peer2:8762/eureka/
eureka.client.serviceUrl.defaultZone=http://IP2:8762/eureka/
#环境信息
#eureka.instance.environment=dev
#设为false,关闭自我保护
eureka.server.enable-self-preservation =false
eureka.instance.leaseExpirationDurationInSeconds=60
eureka.server.evictionIntervalTimerInMs=4000
logging.level.com.netflix.eureka=OFF
logging.level.com.netflix.discovery=OFF
peer2 配置信息
server.port=8762
logging.level.* = debug
logging.file=/pathxxx/eureka-peer2.log
# 是否注册到eureka
#eureka.client.register-with-eureka=true
# 是否从eureka获取注册信息
#eureka.client.fetch-registry=false
spring.application.name=eureka-server
eureka.instance.hostname=peer2
# eureka服务器的地址(注意:地址最后面的 /eureka/ 这个是固定值)
#eureka.client.serviceUrl.defaultZone=http://peer1:8762/eureka/
eureka.client.serviceUrl.defaultZone=http://IP1:8762/eureka/
#环境信息
#eureka.instance.environment=dev
#设为false,关闭自我保护
eureka.server.enable-self-preservation =false
eureka.instance.leaseExpirationDurationInSeconds=60
eureka.server.evictionIntervalTimerInMs=4000
logging.level.com.netflix.eureka=OFF
logging.level.com.netflix.discovery=OFF
问题描述
peer1 上服务列表随时变化
peer2 没问题(因是SIT环境 peer2 和大多服务在一台VM上)
问题分析
因 eureka.server.enable-self-preservation =false 保护模式关闭,eureka会定期清理掉失效服务
因client 检测配置和server端的定期清理 周期不合理,导致注册服务还没发送心跳就被直接定期清理掉。
解决问题
1生产环境开启eureka.server.enable-self-preservation =true 保护模式,不删除注册表中的服务

本文介绍了一种使用两个Eureka服务实例peer1和peer2实现高可用性的配置方案,并详细展示了各自的配置参数。针对peer1服务列表不稳定的问题进行了深入分析,指出原因在于客户端心跳检测与服务器定期清理机制不匹配,并提出了相应的解决方案。
1051

被折叠的 条评论
为什么被折叠?



