Eureka+LoadBalancer实现服务注册与发现

目录

一、相关文章

二、兼容说明

三、服务注册到EurekaServer

四、服务发现

五、LoadBalancer负载均衡


一、相关文章
二、兼容说明
  • 与SpringBoot3兼容的SpringCloud里的eureka-client依赖不含Ribbon,新增了LoadBalancer。

  • 如果想使用Ribbon做负载均衡,参考Eureka+Ribbon实现服务注册与发现-CSDN博客

  • 使用SpringBoot3,即使单独引用了Ribbon也是不生效的。

三、服务注册到EurekaServer

1、父工程cloud-demo3.0引入依赖

Groovy 复制代码
dependencyManagement {  
	imports { mavenBom "com.alibaba.cloud:spring-cloud-alibaba-dependencies:2023.0.0.0-RC1" }  
	imports { mavenBom "org.springframework.cloud:spring-cloud-dependencies:2023.0.1" }  
}  

2、子工程build.gradle引入eureka-client

Groovy 复制代码
//eureka-client  
implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'

//order-service引入springcloud2021开始,使用loadbalancer处理客户端负载均衡  
implementation 'org.springframework.cloud:spring-cloud-starter-loadbalancer'

3、子工程application.yml配置

Groovy 复制代码
eureka:  
	client:  
		service-url:  
			defaultZone: http://127.0.0.1:10086/eureka/

4、启动多个user-service,参考idea中同服务启动多个-CSDN博客

四、服务发现

1、在OrderApplication类创建RestTemplate

java 复制代码
@Bean  
@LoadBalanced  //添加使用负载均衡注解
RestTemplate restTemplate() {  
	return new RestTemplate();  
}

2、服务远程调用

java 复制代码
//示例:在order服根据用户ID拉取user服用户信息
@Override  
public Order getOrderById(Long orderId) {  
	//获取订单信息  
	Order order = orderMapper.getOrderById(orderId);  
	  
	//根据订单用户ID获取用户信息,通过host:port拼接请求路径
	//String url = "http://localhost:8083/user/" + order.getUserId();  
	
	//eureka方式:通过user-service服务名拼接请求路径
	String url = "http://user-service/user/" + order.getUserId();  
	
	//执行远程调用
	User user = restTemplate.getForObject(url, User.class);  
	order.setUser(user);  
	  
	return order;  
}
五、LoadBalancer负载均衡

1、默认规则,详细分析可参考https://blog.csdn.net/BASK2312/article/details/129025006

  • 默认提供了两种不同的负载均衡器,分别是:RandomLoadBalancer(随机负载均衡器)和RoundRobinLoadBalancer(轮询负载均衡器)

2、指定使用随机策略

  • 创建一个类CustomLoadBalancerConfiguration

  • OrderApplication加注解@LoadBalanced、@LoadBalancerClients

java 复制代码
/**  
* Spring Cloud LoadBalancer替代Ribbon实现 随机/轮询 方式负载均衡策略配置  
*/  
public class CustomLoadBalancerConfiguration {  
	/**  
	* 自定义负载均衡策略(随机/轮询)  
	*  
	* @return ReactorLoadBalancer  
	*/@Bean  
	ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment, LoadBalancerClientFactory factory) {  
		String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);  
		//随机
		return new RandomLoadBalancer(factory.getLazyProvider(name, ServiceInstanceListSupplier.class), name); 
		
		//轮询  
		//return new RoundRobinLoadBalancer(factory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);
	}  
}
java 复制代码
@LoadBalancerClients(defaultConfiguration= CustomLoadBalancerConfiguration.class)  
@SpringBootApplication  
public class OrderApplication {  
	public static void main(String[] args) {  
		SpringApplication.run(OrderApplication.class, args);  
	}  
	  
	@Bean  
	@LoadBalanced  //该注解表示使用负载均衡
	RestTemplate restTemplate() {  
		return new RestTemplate();  
	}  
}
相关推荐
wb1897 小时前
Kubernetes服务优化
云原生·容器·kubernetes
Waay12 小时前
图文详解|K8s Pod内部结构
docker·云原生·kubernetes
openFuyao13 小时前
以开源之力,突破多样化算力困局——openFuyao开源一周年背后的故事
人工智能·云原生·开源·openfuyao·多样化算力·集群软件
JiaWen技术圈13 小时前
IaC 双引擎:Terraform + Ansible 完整最佳实践
云原生·ansible·terraform
步步为营DotNet18 小时前
深入.NET 11:.NET Aspire 在云原生资源编排与管理的卓越实践
云原生·.net
密瓜智能18 小时前
HAMi 正式接入 Kubernetes DRA:下一代 GPU 资源模型实践指南
云原生·容器·kubernetes
Elastic 中国社区官方博客19 小时前
用于调试 LLM 延迟、成本和 GPU 饱和度的 ES|QL 查询
大数据·人工智能·elasticsearch·搜索引擎·ai·云原生·serverless
李李李li19 小时前
debian13.3安装k8s
云原生·容器·kubernetes
姚不倒19 小时前
Go语言实战:构建一个安全的计算器服务(接口、错误处理与Panic恢复)
云原生·golang
AI云原生19 小时前
远程控制软件进入协作阶段:ToDesk、向日葵、AnyDesk、RustDesk怎么选?
运维·服务器·网络·windows·docker·云原生·开源软件