SpringCloud 将Ribbon与Eureka一起使用
当Eureka与Ribbon结合使用时(也就是说,两者都在类路径上),ribbonServerList
被扩展名DiscoveryEnabledNIWSServerList
覆盖,这将填充{71中的服务器列表/}。它还用NIWSDiscoveryPing
替换了IPing
接口,该接口委托给Eureka确定服务器是否启动。默认安装的ServerList
是DomainExtractingServerList
。其目的是不使用AWS AMI元数据(这就是Netflix所依赖的)使元数据可用于负载均衡器。默认情况下,服务器列表是使用实例元数据中提供的“ zone ”信息构建的(因此,在远程客户端上,设置为eureka.instance.metadataMap.zone
)。如果缺少该字段,并且设置了approximateZoneFromHostname
标志,则它可以使用服务器主机名中的域名作为该区域的代理。一旦区域信息可用,就可以在ServerListFilter
中使用它。默认情况下,它用于在与客户端相同的区域中定位服务器,因为默认值为ZonePreferenceServerListFilter
。默认情况下,以与远程实例相同的方式(即通过eureka.instance.metadataMap.zone
)确定客户端的区域。
设置客户端区域的传统“ archaius ”方法是通过名为“ @zone”的配置属性。如果可用,Spring Cloud优先于所有其他设置使用该设置(请注意,该键必须在YAML配置中用引号引起来)。
如果没有其他区域数据源,则根据客户端配置(而不是实例配置)进行猜测。我们取
eureka.client.availabilityZones
(这是从区域名称到区域列表的映射),然后为实例自己的区域拉出第一个区域(即eureka.client.region
,其默认值为“ us-east-1” ”,以与本机Netflix兼容)。
更多建议: