探究 Eureka 在 Spring Boot 中的配置注入与统一管理机制(下)——第三节

今天我们来探讨下已经加载到Spring容器中的LoadBalancerEurekaAutoConfiguration自动配置类是如何进行初始化的。

LoadBalancerEurekaAutoConfiguration

java 复制代码
@Configuration(proxyBeanMethods = false)
@EnableConfigurationProperties
@ConditionalOnClass(LoadBalancerClientConfigurationRegistrar.class)
@LoadBalancerClients(defaultConfiguration = EurekaLoadBalancerClientConfiguration.class)
@ConditionalOnProperty(name = "eureka.client.enabled", matchIfMissing = true)
public class LoadBalancerEurekaAutoConfiguration {
    ......
}

该配置类用在spring cloud环境中,为Spring Cloud LoadBalancer与Eureka的集成提供自动配置支持。

初始化时创建的Bean有两个,分别是eurekaLoadBalancerProperties和zoneConfig。

eurekaLoadBalancerProperties负责配置Eureka负载均衡器的相关属性。

java 复制代码
    @Bean
	@ConditionalOnMissingBean
	EurekaLoadBalancerProperties eurekaLoadBalancerProperties() {
		return new EurekaLoadBalancerProperties();
	}

例如,可以通过配置文件设置spring.cloud.loadbalancer.eureka.approximateZoneFromHostname=true来开启从主机名中提取区域信息的功能。

java 复制代码
@ConfigurationProperties("spring.cloud.loadbalancer.eureka")
public class EurekaLoadBalancerProperties {

	/**
	 * Used to determine whether we should try to get the `zone` value from host name.
	 */
	private boolean approximateZoneFromHostname = false;

	public boolean isApproximateZoneFromHostname() {
		return approximateZoneFromHostname;
	}

	public void setApproximateZoneFromHostname(boolean approximateZoneFromHostname) {
		this.approximateZoneFromHostname = approximateZoneFromHostname;
	}

}

zoneConfig负责配置负载均衡器的区域信息。

java 复制代码
    public static final String LOADBALANCER_ZONE = "spring.cloud.loadbalancer.zone";    

    @Bean
	@ConditionalOnMissingBean
	LoadBalancerZoneConfig zoneConfig(Environment environment) {
		return new LoadBalancerZoneConfig(environment.getProperty(LOADBALANCER_ZONE));
	}

这两个bean的创建条件都是Spring容器中不存在时才会创建。

接下来,我们看下@LoadBalancerClients注解

java 复制代码
@Configuration
@ConditionalOnBean({ LoadBalancerZoneConfig.class, EurekaLoadBalancerProperties.class })
public class EurekaLoadBalancerClientConfiguration {
    ......
}

该注解会将负载均衡默认的配置设置为EurekaLoadBalancerClientConfiguration配置类。

该配置类生效的条件是类路径中存在LoadBalancerZoneConfig和EurekaLoadBalancerProperties类。

该配置类实例化后,LoadBalancerZoneConfig会绑定区域的配置为eurekaClientConfig的区域属性。

java 复制代码
    @PostConstruct
	public void postprocess() {
		if (!StringUtils.isEmpty(zoneConfig.getZone())) {
			return;
		}
		String zone = getZoneFromEureka();
		if (!StringUtils.isEmpty(zone)) {
			if (LOG.isDebugEnabled()) {
				LOG.debug("Setting the value of '" + LOADBALANCER_ZONE + "' to " + zone);
			}
			zoneConfig.setZone(zone);
		}

最后简单来聊聊Spring Cloud LoadBalancer与Ribbon**。**

Spring Cloud LoadBalancer是 Spring Cloud 生态的新一代负载均衡解决方案。而Ribbon是 Netflix 开源的客户端负载均衡工具。

Ribbon曾经是 Spring Cloud 中主要的负载均衡工具。随着 Spring Cloud 的不断演进,Ribbon的地位逐渐被 Spring Cloud LoadBalancer 所取代,它是 Spring Cloud 生态中更推荐的负载均衡解决方案。

相关推荐
代码栈上的思考12 分钟前
消息队列:内存与磁盘数据中心设计与实现
后端·spring
heimeiyingwang13 分钟前
【架构实战】云原生架构设计原则
云原生·架构
程序员小假1 小时前
我们来说一下 b+ 树与 b 树的区别
java·后端
Meepo_haha1 小时前
Spring Boot 条件注解:@ConditionalOnProperty 完全解析
java·spring boot·后端
sheji34162 小时前
【开题答辩全过程】以 基于springboot的房屋租赁系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
Cyber4K2 小时前
【妙招系列】Harbor 镜像私有仓库搭建手册
linux·云原生·容器
Victor3563 小时前
MongoDB(57)如何优化MongoDB的查询性能?
后端
王码码20353 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
Victor3563 小时前
MongoDB(58)如何使用索引优化查询?
后端
行百里er3 小时前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·代码规范