Spring Cloud - Spring Cloud 负载均衡(Ribbon 负载均衡概述、Ribbon 使用)

一、Ribbon 负载均衡概述

  • Ribbon 是 Spring Cloud 提供的一种负载均衡解决方案,Ribbon 是 Netflix 发布的负载均衡器,Spring Cloud 对其进行了封装,形成了 Spring Cloud Ribbon

  • Ribbon 的使用同样需要结合 Eureka Server

  • 负载均衡算法:轮询、随机、加权轮询、加权随机


二、Ribbon 使用

1、具体实现
(1)配置工程
  • 创建子工程(Module),在 pom.xml 文件中配置相关依赖
xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>SpringCloudTest</artifactId>
        <groupId>com.my</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>Ribbon</artifactId>

    <!-- Eureka Client -->
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>
    
</project>
(2)配置文件
  • 在 resources 目录下创建并配置 application.yaml 文件
yaml 复制代码
server:
  port: 8040
spring:
  application:
    name: ribbon
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
  instance:
    prefer-ip-address: true
(3)Config
  • 创建 MyConfig 配置类,将 RestTemplate 对象注入到 IoC 容器中,并实现负载均衡
java 复制代码
package com.my.config;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;

@Configuration
public class Myconfig {

    @Bean

    // 添加负载均衡注解
    @LoadBalanced
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
}
(4)Controller
  • 创建 RibbonHandler 类
java 复制代码
package com.my.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

@RestController
@RequestMapping("/ribbon")
public class RibbonHandler {

    @Autowired
    private RestTemplate restTemplate;

    @GetMapping("/test")
    public String test() {
        return restTemplate.getForObject("http://ServerConsumer/consumer//zuulLoadBalancingTest", String.class);
    }
}
(5)启动类
  • 创建启动类
java 复制代码
package com.my;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class RibbonApplication {
    public static void main(String[] args) {
        SpringApplication.run(RibbonApplication.class, args);
    }
}
2、测试
  1. 依次启动注册中心,服务提供者,服务消费者(第一个启动类),Ribbon

  2. 修改服务消费者的配置文件(application.yaml)

    • 将 server.port: 8020 修改为 server.port: 8021
  3. 再次启动一个服务消费者(使用第二个启动类)

  4. 使用 Postman 测试,多次访问,观察端口号的变化

相关推荐
蓁蓁啊11 分钟前
GCC 头文件搜索路径:-I vs -idirafter 深度解析
java·前端·javascript·嵌入式硬件·物联网
龙门吹雪14 分钟前
GO 语言处理多个布尔选项的实现方案
开发语言·后端·golang·布尔选项·标识位
Coder_Boy_15 分钟前
基于SpringAI的在线考试系统-核心业务流程图(续)
java·大数据·人工智能·spring boot·流程图
毕设源码-钟学长16 分钟前
【开题答辩全过程】以 基于Springboot vue肢体残疾人就业服务网站的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
ss27320 分钟前
idea中git更新项目:将传入更改合并到当前分支,在传入更改上变基当前分支
java·git·intellij-idea
不穿格子的程序员23 分钟前
从零开始写算法——二叉树篇6:二叉树的右视图 + 二叉树展开为链表
java·算法·链表
Coder_Boy_24 分钟前
基于SpringAI的在线考试系统-核心业务流程图
java·数据库·spring boot·软件工程
源代码•宸36 分钟前
Golang原理剖析(map面试与分析)
开发语言·后端·算法·面试·职场和发展·golang·map
WenJGo36 分钟前
基于 IPIDEA 的 GitHub 代码文件抓取与数据可视化实践(Python 实现)
后端