这篇文章主要介绍了SpringCloud笔记HoxtonNetflix之Ribbon负载均衡,Ribbon是管理HTTP和TCP服务客户端的负载均衡器,Ribbon具有一系列带有名称的客户端(Named Client),对SpringCloud Ribbon负载均衡相关知识感兴趣的朋友一起看看吧
Ribbon使用
- Ribbon是管理HTTP和TCP服务客户端的负载均衡器,Ribbon具有一系列带有名称的客户端(Named Client),也就是带有名称的Ribbon客户端(Ribbon Client)。
- 每个客户端由可配置的组件构成,负责一类服务的调用请求。SpringCloud通RibbonClientConfiguration 为每个Ribbon客户端创建ApplicationContext上下文来进行组件装配。Ribbon作为SpringCloud的负载均衡机制的实现,可以与OpenFeign和RestTemplate进行无缝对接,让二者具有负载均衡的能力。
负载均衡
- 当系统面临大量的用户访问,负载过高的时候,通常会增加服务器数量来进行横向扩展,多个服务器的负载需要均衡,以免出现服务器负载不均衡,部分服务器负载较大,部分服务器负载较小的情况 通过负载均衡,使得集群中服务器的负载保持在稳定高效的状态,从而提高整个系统的处理能力。
- 系统的负载均衡分为软件负载均衡和硬件负载均衡,软件负载均衡使用独立的负载均衡程序或系统自带的负载均衡模块完成对请求的分配派发,硬件负载均衡通过特殊的硬件设备进行负载均衡的调配。
- 软负载均衡一般分为两种类型,基于DNS负载均衡和基于IP的负载均衡。利用DNS 实现负载均衡,就是在DNS服务器配置多个A记录,不同的 DNS请求解析到不同IP地址。基于IP的负载均衡根据请求的IP 行负载均衡,LVS就是具有代表性的基于IP负载均衡实现。
- Ribbon使用的是客户端负载均衡,客户端负载均衡和服务端负载均衡最大的区别在于服务端地址列表的存储位置,在客户端负载均衡中,所有的客户端节点都有一份自己要访问的服务端地址列表,这些列表统统都是从服务注册中心获取的;而在服务端负载均衡中,客户端节点只知道单一服务代理的地址,服务代理则知道所有服务端的地址。在SpringCloud中我们如果想要使用客户端负载均衡,可以使用@LoadBalanced注解,这样客户端在发起请求的时候会根据负载均衡策略从服务端列表中选择一个服务端,向该服务端发起网络请求,从而实现负载均衡。
代码示例
注册中心
这里是Eureka作为服务注册中心,为OpenFeign提供服务端信息的获取,比如说服务的IP地址和端口,使用前面搭建好的项目(eureka-server)。
Provider
在idea中新建两个项目运行主类,选择前面创建好的项目(eureka-provider)。
设置不同运行主类,使用不同端口号,然后启动三个不同端口号的provider。
接口实现
调用不同的服务端,会返回对应服务端的接口。
@RestController
@RequestMapping("/api")
public class PoroviderController {
@Value("${server.port}")
private String serverPort;
@PostMapping("/sayHello")
public String sayHello(String name) {
return "我是服务端" + serverPort + ",你好" + name;
}
}
Consumer
新建一个spring-boot工程,取名为consumer-ribbon,在pom文件引入ribbon需要的依赖。
添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
配置端口、注册中心等
server:
port: 8091
servlet:
context-path: /ribbon
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka/
instance:
status-page-url-path: ${server.servlet.context-path}/info
health-check-url-path: ${server.servlet.context-path}/health
spring:
application:
name: consumer-ribbon
- 负载均衡策略 SpringCloud为客户端负载均衡创建了特定的注解@LoadBalanced,我们只需要使用该注解修饰创建RestTemplate实例的@Bean函数,SpringCloud就会让RestTemplate使用相关的负载均衡策略,默认情况下使用Ribbon。
- 除了@LoadBalanced之外,Ribbon还提供@RibbonClient注解。该注解可以为Ribbon客户端声明名称和自定义配置。 name属性可以设置客户端的名称, configuration属性则会设置Ribbon相关的自定义配 类。
@Configuration
public class RestTemplateConfig {
/**
* @return org.springframework.web.client.RestTemplate
* @description 注入一个可以进行负载均衡的RestTemple用于服务问调用
* @author fengfan
* @date 2022/5/18 14:43
*/
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
yml配置负载均衡策略
# 配置的方式设置Ribbon的负载均衡策略
EUREKA-PROVIDER: # 设置服务提供方的应用名称
ribbon:
NFloadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 策略类(全路径名)
代码方式配置负载均衡策略
@Configuration
public class RibbonConfig {
/**
* @return com.netflix.loadbalancer.IRule
* @description 配置随机负载策略
* @author fengfan
* @date 2022/5/20 16:04
*/
@Bean
public IRule iRule(){
return new RandomRule();
}
}
@SpringBootApplication
@EnableEurekaClient
@RibbonClient(name = "consumer-ribbon", configuration = RibbonConfig.class)
public class ConsumerRibbonApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerRibbonApplication.class, args);
}
}
客户端调用实现
@RestController
@RequestMapping("/api")
public class ConsumerRibbonController {
@Resource
private RestTemplate restTemplate;
@PostMapping("/getServerInfo")
public String getServerInfo(){
MultiValueMap<String, String> body = new LinkedMultiValueMap<>();
body.add("name", "consumer8081");
ResponseEntity<String> responseEntity = restTemplate.postForEntity("http://EUREKA-PROVIDER/provider/api/sayHello", body, String.class);
return responseEntity.getBody();
}
}
测试
多次请求的服务端,端口随机变化,证明配置成功。
到此这篇关于SpringCloud笔记(Hoxton)Netflix之Ribbon负载均衡示例代码的文章就介绍到这了,更多相关SpringCloud Ribbon负载均衡内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:SpringCloud笔记(Hoxton)Netflix之Ribbon负载均衡示例代码
基础教程推荐
- java基础知识之FileInputStream流的使用 2023-08-11
- Java文件管理操作的知识点整理 2023-05-19
- springboot自定义starter方法及注解实例 2023-03-31
- java实现多人聊天系统 2023-05-19
- Java数据结构之对象比较详解 2023-03-07
- Java实现线程插队的示例代码 2022-09-03
- ConditionalOnProperty配置swagger不生效问题及解决 2023-01-02
- Java并发编程进阶之线程控制篇 2023-03-07
- JDK数组阻塞队列源码深入分析总结 2023-04-18
- Java实现查找文件和替换文件内容 2023-04-06