在SpringCloud中,负载均衡的搭建主要依赖于调用者和Ribbon这两个关键组件。SpringCloud中的调用者集成了负载均衡功能,由调用者决定来调用哪个节点的服务,这就是所谓的客户端负载均衡。SpringCloud Ribbon是一个基于客户端的负载均衡工具,它可以自动将面向服务的REST模板请求转换成客户端负载均衡的服务调用。Ribbon还维护了一个服务列表,当服务实例发生变动时,Ribbon会自动更新服务列表。通过使用SpringCloud和Ribbon,可以有效地实现微服务架构中的负载均衡,提高系统的性能和可靠性。
在微服务架构中,服务之间的调用关系变得复杂,为了提高系统的可用性和稳定性,我们需要引入负载均衡机制,Spring Cloud是一套微服务解决方案,其中包含了Eureka、Ribbon等组件,可以实现服务注册与发现以及负载均衡,本文将详细介绍如何使用Spring Cloud搭建负载均衡。
环境准备
1、JDK:建议使用JDK 1.8及以上版本。

2、Maven:用于构建和管理项目依赖。
3、Spring Boot:基于Spring的快速开发框架。
4、Spring Cloud:一套微服务解决方案。
创建父工程
1、使用Maven创建一个父工程,并添加如下依赖:
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.4</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
2、在父工程的pom.xml中添加spring-boot-maven-plugin插件,以便生成可执行jar包。
创建服务注册中心
1、创建一个Spring Boot项目,作为服务注册中心。
2、在项目的application.yml文件中配置Eureka相关信息:

server:
port: 8761
eureka:
instance:
hostname: localhost
client:
registerWithEureka: false
fetchRegistry: false
serviceUrl:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
3、在项目的主类上添加@EnableEurekaServer注解,启用Eureka服务注册中心功能。
4、运行项目,访问http://localhost:8761,查看Eureka服务注册中心页面。
创建服务提供者
1、创建一个Spring Boot项目,作为服务提供者。
2、在项目的pom.xml中添加spring-cloud-starter-netflix-eureka-client依赖,以便实现服务注册与发现。
3、在项目的application.yml文件中配置Eureka相关信息:
server:
port: 8080
spring:
application:
name: service-provider
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
4、在项目的主类上添加@EnableDiscoveryClient注解,启用服务注册与发现功能。
5、创建一个接口,定义需要暴露的服务方法:

@RestController
public class ServiceProviderController {
@GetMapping("/hello")
public String hello() {
return "Hello, I'm service provider!";
}
}
6、运行项目,访问http://localhost:8080/hello,查看服务提供者的接口返回结果,访问Eureka服务注册中心页面,可以看到服务提供者已经成功注册到服务注册中心。
创建服务消费者
1、创建一个Spring Boot项目,作为服务消费者。
2、在项目的pom.xml中添加spring-cloud-starter-netflix-eureka-client依赖,以便实现服务注册与发现。
3、在项目的application.yml文件中配置Eureka相关信息:
server:
port: 8090
spring:
application:
name: service-consumer
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
4、在项目的主类上添加@EnableDiscoveryClient注解,启用服务注册与发现功能,5. 创建一个接口,定义需要调用的服务方法:
@RestController
public class ServiceConsumerController {
@Autowired
private DiscoveryClient discoveryClient; // 获取服务发现客户端实例,用于查找服务提供者信息。
@GetMapping("/hello")
public String hello() throws InterruptedException {
List<ServiceInstance> instances = discoveryClient.getInstances("service-provider"); // 根据服务名获取服务提供者实例列表。
if (instances == null || instances.isEmpty()) { // 如果实例列表为空,说明没有找到对应的服务提供者。
throw new IllegalStateException("No service provider found!"); // 抛出异常。
} else { // 如果实例列表不为空,说明找到了对应的服务提供者,选择其中一个实例进行调用。
本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/482040.html
如有侵犯您的合法权益请发邮件951076433@qq.com联系删除