Spring Cloud学习笔记(Ribbon):Ribbon的应用样例

news2024/12/26 10:48:08

这是本人学习的总结,主要学习资料如下
- 马士兵教育

  • 1、Ribbon简介
    • 1.1、架构图
    • 1.2、简单实现负载均衡
  • 2、配置负载均衡策略
    • 2.1、IRule
    • 2.2、使用IRule简单示例
      • 2.2.1、Overview
      • 2.2.1、注入```IRule```
      • 2.2.2、关联```IRule```和服务

1、Ribbon简介

我们都知道Ribbon是用于负载均衡的。提供同一种服务的Client可能有多个,比如有多个User Client提供查询用户信息的服务,使用Ribbon就能简单地达到负载均衡的效果。

1.1、架构图

想要使用Ribbon,无论是服务提供者还是调用服务者都必须作为Client注册到Server中。
在这里插入图片描述

1.2、简单实现负载均衡

如果是使用RestTemplate请求服务,那么可以在RestTemplatebean配置上加上@LoadBalanced注解即可。之后使用RestTemplate调用服务就会自动实现负载均衡。这样的方式是循环轮询的调用服务。

@Configuration
public class RestConfig {
    @LoadBalanced
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

现在我们有两个UserClient提供服务,user-client1user-client2。用order-client去调用11次,因为是循环轮询调用,会发现会交替调用user-client1user-client2

这是user-client1user-client2application.yml,大部分配置都一样,只有port不相同。spg.application.name必须一样,不然Ribbon会认为他们不提供同一种服务。

这里他们两都是user-client

spring:
  application:
    name: user-client

这是order-client调用的代码。只需要指定spring.application.name,路径和参数即可。

private int i = 0;
@Override
public String getUserInfo(String userId) {
    return restTemplate.getForObject("http://user-client/getUserInfo?userId=" + i++, String.class);
}

可以看到两个user-client循环提供服务。在这里插入图片描述

在这里插入图片描述



2、配置负载均衡策略

2.1、IRule

IRule是代表规则的接口,它的实现类有RoundRobinRule,即默认调用服务的规则,循环调用。还有RondamRule,随机选取服务调用。

还有其他的策略这里就不一一介绍了。总之IRule及其实现类给我们提供了一些常见的选择策略。大部分情况我们可以选择其中一种直接用,不用再自己写。


2.2、使用IRule简单示例

2.2.1、Overview

  1. 配置IRule的bean,将其中一个实现类注入到Spring中。这里我将选取RandomRule注入。
  2. 将注入的IRule与具体的服务客户端关联起来,让Ribbon知道什么服务器用什么规则。在这里服务者是user-client,我们需要把这个和刚才注入的IRule绑定起来。

通过以上两步就可以自定义负载均衡策略。

2.2.1、注入IRule

@Configuration
public class OrderRibbonRule {
    @Bean
    public IRule ribbonRule() {
        return new RandomRule();
    }
}

2.2.2、关联IRule和服务

在这里我有两台机器提供服务,他们都是spring.application.name=user-client,我们需要将刚才的注入的IRuleuser-client关联起来。

@Configuration
@RibbonClient(name = "user-client", configuration = OrderRibbonRule.class)
public class UserRibbonConfiguration {
}

之后通过http://localhost:9002/createOrder访问多次,可以看到Ribbon随机选取机器提供服务。

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1619899.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据结构】算法效率揭秘:时间与空间复杂度的较量

前言 在计算机科学中,时间复杂度和空间复杂度是衡量算法性能的两个重要指标。它们分别表示算法在执行过程中所需的时间和空间资源。了解这两个概念有助于我们评估和比较不同算法的优劣,从而选择更合适的算法解决问题~ 欢迎关注个人主页:逸狼 …

电子邮件免费版有哪些?免费注册电子邮箱

电子邮件有付费版和免费版两种类型,付费版通常具有更大的电子邮箱容量和更强大的电子邮箱功能。但是对于我们个人用户或者是中小型企业来说注册电子邮箱免费版的就够日常使用了。电子邮件的免费版提供商有Zoho Mail、微软、腾讯等,今天我们就来具体了解下…

【Linux】使用Jenkins + svn + springboot自动构建jar包并自动打包在服务器上运行

👨‍🎓博主简介 🏅云计算领域优质创作者   🏅华为云开发者社区专家博主   🏅阿里云开发者社区专家博主 💊交流社区:运维交流社区 欢迎大家的加入! 🐋 希望大家多多支…

报告!这里发现了一个赛博炼丹的神级平台!

众所周知,“赛博炼丹”是一个AI开发研究领域古老又神秘的活动,它往往对炼丹平台有很高的要求。如果你也是一路从“炼丹小白”成长到“资深AI算法工程师”,那你一定懂我在说什么?说好了,天台见! GpuMall智算…

redis单线程模型

工作原理 在Redis中,当两个客户端同时发送相同的请求时,Redis采用单线程模型来处理所有的客户端请求,会依次处理这些请求,每个请求都会按照先后顺序被执行,不会同时处理多个请求。使得Redis能够避免多线程并发访问数据…

探索比特币符文热:市场趋势与持续性分析

在加密货币世界中,比特币一直是备受关注的焦点之一。然而,近年来,随着DeFi(去中心化金融)的兴起,一种新的潮流开始崭露头角——比特币符文。本文将探讨比特币符文的兴起,分析市场趋势&#xff0…

基于深度学习网络的十二生肖图像分类matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ............................................................... for i 1:16subplot(4,4,…

2-2 任务:闰年判断

本次课,我们讨论了闰年的判断方法、关系运算符与关系表达式、逻辑运算符与逻辑表达式,以及流程控制结构中的选择结构。 闰年判断 闰年是为了使日历年与地球绕太阳公转的时间保持一致而设定的,具有366天。闰年的判断规则如下: 普…

VMware:重塑跨平台计算的未来,畅享虚拟世界的无限可能

在数字化时代的浪潮中,跨平台计算已成为我们日常生活和工作中不可或缺的一部分。VMware,作为全球领先的虚拟化技术提供商,凭借其卓越的虚拟机解决方案,正在重塑跨平台计算的未来,让我们能够畅享虚拟世界的无限可能。 …

UE5增强输入系统 Enhanced Input

关键字: Enhanced Input 、 输入、映射、事件、鼠标、键盘、键鼠、动作、Trigger、触发器、 疑问: 新输入系统怎么做一个基础的案例?Trigger修改器中每个项都是什么功能?功能边界问题:如时刻、时段、单次事件、持续事…

Stable diffusion中这些重要的参数你一定要会用

Stable diffusion中这些重要的参数你一定要会用 如果你已经使用Stable diffusion AI模型生成了一些图像,但发现它们并不完全符合你的期望,不用担心,你可以通过调整一些基本的生成参数来进行自定义,以达到更加满意的效果。 使用S…

2024年——区块链技术进入全新高度

随着区块链技术的不断发展,铭文系统作为其重要组成部分,逐渐引起了人们的关注。本文将从技术原理、应用场景、未来发展等方面,对区块链中的铭文系统进行深入探讨。 【技术原理】 铭文系统是一种利用区块链技术实现的数字身份认证系统。在区…

(Oracle)SQL优化案例:组合索引优化

项目场景 项目上的ETL模型里有如下SQL语句。执行速度非常慢,每次只查询200条数据,但却需要20多秒的时间。再加上该SQL查询出的数据同步频率很高,这个速度是完全不能忍受的。 因为项目隐私,所以对表及字段做了改写。 SELECT ID…

嵌入式Linux八股(三)——计算机基础

三、计算机基础 01.操作系统 01.进程几种状态 02.锁 互斥锁:互斥锁是一种用于线程同步的工具,能够保证同一时刻只有一个线程可以访问共享资源。如果一个线程已经取得了互斥锁,其他尝试获得该锁的线程将会被阻塞,直到第一个线程…

基于springboot+vue的游艇停泊系统

一、系统架构 前端:vue2 | element-ui |html 后端:springboot | mybatis-plus 环境:jdk1.8 | mysql | maven | node 二、代码及数据库 三、功能介绍 01. web端-登录 02. web端-系统首页1 03. web端-系统首页2 04. web端-泊位 05. web…

【南京工程学院×朗汀留学】部分录取案例合集

朗汀留学 X 南京工程学院 作为深耕留学的专业资深团队,朗汀留学成功帮助上千名学生出国留学。 在此我们将南京工程学院的部分留学案例作以总结,以供新生参考。再次恭喜所有 获得理想大学offer的学生们,你们的努力让梦想照进现实。 学校介绍…

linux下编译c++程序报错“undefined reference to `std::allocator<char>::allocator()‘”

问题 linux下编译c程序报错“undefined reference to std::allocator::allocator()”。 原因 找不到c标准库文件。 解决办法 开始尝试给gcc指令添加-L和-l选项指定库路径和库文件名,但是一直不成功,后来把gcc改为g就可以了。

关于路由过滤、路由策略的实验eNSP

具体接口IP地址如下图所示 第一步:配置IP R1: [R1]int g 0/0/0 [R1-GigabitEthernet0/0/0]ip ad [R1-GigabitEthernet0/0/0]ip address 100.1.1.1 24 Apr 23 2024 19:35:38-08:00 R1 %%01IFNET/4/LINK_STATE(l)[0]:The line protocol IP on the interface Giga…

智能AI伪原创,高效率一键生成优质文章

如今,内容创作已经成为许多企业和个人关注的焦点。然而,随着信息量的不断增加,想要在短时间内创作出优质的文章成为了一个挑战。但随着人工智能技术的飞速发展,智能AI伪原创的出现,为我们提供了一种全新的解决方案。这…

TensorRT plugins and ONNX parser编译

https://github.com/NVIDIA/TensorRT是TensorRT plugins and ONNX parser,并不包含TensorRT的nvinfer库(libinfer.so、nvinfer.dll),此部分并未开源,只能使用官方支持的平台、环境https://developer.nvidia.com/tensor…