负载均衡-Ribbon-自定义负载均衡算法

1.Ribbon 是什么

  • SpringCloud Ribbon 是基于 Netflix Ribbon 实现的一套客户端负载均衡的工具
  • 主要功能是提供客户端的软件负载均衡算法,将 Netflix 的中间服务处连接在一起
  • Ribbon的客户端组件提供一系列完整的配置项,如:连接超时、重试等。简单的说就是在配置文件中列出 LoadBalance
    (LB:负载均衡)后面所有的机器,Ribbon 会自动帮你基于某种规则去连接这些机器

    1.2 负载均衡(LB)
  • 核心作用:就是将用户的请求平摊在多个服务器上,从而达到系统的 High Availability(HA :高可用)
  • 常见的负载均衡软件有 Nginx、Lvs 等
  • Dubbo 和 SpringCloud 都提供了负载均衡,SpringCloud 的负载均衡算法可以自定义
  • 负载均衡算法实现的方式:轮询、权重、随机
  • 负载均衡的简单分类:
    1、集中式
    在服务的 消费者 和 提供者之间使用独立的 LB 设施,如Nginx(反向代理服务器) ,由该设施负载把访问请求通过某种策略发送至服务的提供者
    2、进程式
    将LB逻辑集成到 消费者,消费者 从服务注册中心得到哪些地址可用,然后自己再从这些地址中选出一个合适服务器
    Ribbon 就属于进程内 LB ,它只是一个类库,集成与消费者进程,消费者通过他来获取到服务提供者的地址
    2.1 整合 Ribbon
  1. 在 POM 文件中添加 Ribbon、Eureka 依赖
java 复制代码
	<!--ribbon-->
	<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-ribbon -->
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-ribbon</artifactId>
		<version>1.4.7.RELEASE</version>
	</dependency>
	<!--Eureka 服务提供者-->
	<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-eureka -->
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-eureka</artifactId>
		<version>1.4.7.RELEASE</version>
	</dependency>

2.编写 application.yml

java 复制代码
# Eureka
eureka:
  client:
    # 不向注册中心注册自己
    register-with-eureka: false
    # 配置 可连接的注册中心
    service-url:
      defaultZone: http://127.0.0.1:7001/eureka/,http://127.0.0.2:7002/eureka/

3.在主启动类上添加 Eureka 启动项 : @EnableEurekaClient

4.在之前把 RestTemplate 注册到 Bean 的配置方法上添加一个注解

5.修改控制层

java 复制代码
 /**提供者 URL 的前缀
 *
 * 不使用 Ribbon 时 ,这里就是第一中写法
 *
 * 使用 Ribbon 实现负载均衡 时,这里就不能写死为一个地址,
 *       而需要通过注册中心的服务名来访问
 *       服务名:在 提供者 YML 文件中配置的 spring:application:name: 的值
 *            或者 监控页面的 Application 字段值
 */
//private static final String REST_URL_PREFIX = "http://localhost:8081";

private static final String REST_URL_PREFIX = "http://SpringCloud-02-provider";

3.自定义策略(简单示例)

  • 可以点开刚刚看的那个 RandomRule 的源代码,复制过来修改一下
  • 修改要求:每个提供者访问五次
java 复制代码
public class DiyRule extends AbstractLoadBalancerRule {

    public Server choose(ILoadBalancer lb, Object key) {
        if (lb == null) {
            return null;
        } else {
            Server server = null;

            while(server == null) {
                if (Thread.interrupted()) {
                    return null;
                }
                // 获得可获得(活着的)的服务
                List<Server> upList = lb.getReachableServers();
                // 获得所有的服务
                List<Server> allList = lb.getAllServers();
                int serverCount = allList.size();
                if (serverCount == 0) {
                    return null;
                }

            //==上面是写死的======中间是修改部分==================
                System.out.println("自定义的 Rule");
                System.out.println(upList.size());
                // 访问某一个提供者的次数
                int times = 0;
                // 提供者的下标
                int index = 0;
                // 从活着的服务中随机获取一个
                server = (Server)upList.get(index);
                if (times < 4){
                    times++;
                }else {
                    times = 1;
                    index = (index + 1) % upList.size();
                }

            //==下面是写死的======中间是修改部分===================

                if (server == null) {
                    Thread.yield();
                } else {
                    if (server.isAlive()) {
                        return server;
                    }

                    server = null;
                    Thread.yield();
                }
            }

            return server;
        }
    }

    @Override
    public void initWithNiwsConfig(IClientConfig iClientConfig) {

    }

    @Override
    public Server choose(Object o) {
        return null;
    }
}

2.MyRule 类

java 复制代码
@Configuration
public class CustomizedRule {
    /**
     * 修改默认的负载均衡策略
     */
    @Bean
    public IRule customize(){
        // 先使用已经实现的策略------随机
        return new DiyRule();
    }
}

3.在主启动类上添加

java 复制代码
// configuration:标注 Rule 的配置类 ; name:标注需要配置的服务名
@RibbonClient(name = "SPRINGCLOUD-PROVIDER", configuration = CustomizedRule.class)

Eureka 和 Ribbon 整合以后,在消费端,就不需要关系请求服务的 IP地址 和 端口号了,就只需要知道服务名称,直接调用即可

相关推荐
Hello:CodeWorld19 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi820 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang1 天前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby1 天前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠1 天前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力1 天前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly1 天前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1231 天前
SolidWorks草图转三维DWG技巧
算法
redaijufeng1 天前
C++雾中风景7:闭包
c++·算法·风景
小欣加油1 天前
leetcode287寻找重复数
数据结构·c++·算法·leetcode