news 2026/4/18 5:07:39

3. SpringCloud之Ribbon使用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
3. SpringCloud之Ribbon使用

image.png

Ribbon 是一个独立的组件,是用来进行远程接口调用的,代码如下
通过 getForObject 方法可以掉到用 micro-order 服务的,order/list 接口。然后在调用期间会存在负载均衡,micro-order 服务对应有几个服务实例就会根据负载均衡算法选择某一个去调用。

1. 测试代码

1.1. 启动两个订单服务

端口号分别为9011,9012

image.png

1.2. 改造获取订单接口

返回当前服务实例的占用的端口号,用来判断当前服务是哪个实例

@RequestMapping("/order") @RestController public class OrderController { @Value("${server.port}") String port; @GetMapping("/list") public String getOrderList(String username) { return "该服务端口号:" + port + ",这是用户 :" + username + " 所有的订单信息"; } }

1.3. 调用用户服务的获取订单接口,

@RequestMapping("/user") @RestController public class UserController { @Autowired private RestTemplate restTemplate; @Bean @LoadBalanced public RestTemplate restTemplate() { return new RestTemplate(); } @GetMapping("/orderList") public String getOrderList(String username) { return restTemplate.getForObject("http://" + "micro-order" + "/order/list?username=" + username, String.class); } }

会发现,对订单服务的调用会存在负载均衡,在两个订单服务之间 切来切去。

image.png

2. Ribbon 配置

2.1. Application.properties 配置

# 关闭 ribbon 访问注册中心 Eureka Server 发现服务,但是服务依旧会注册。 #true 使用 eureka false 不使用。如果是false,那么表示要调用的服务列表从下面这个参数中获取,不然就从eureka-server中获取,这样扩容服务提供方的话,需要改配置文件与动态扩容的理念相悖,不建议大家使用 ribbon.eureka.enabled=true spring.cloud.loadbalancer.retry.enabled=true ###指定调用的节点 ###ribbon.eureka.enabled=false ##micro-order.ribbon.listOfServers=localhost:8001 ##单位 ms ,请求连接超时时间 #micro-order.ribbon.ConnectTimeout=1000 ##单位 ms ,请求处理的超时时间 #micro-order.ribbon.ReadTimeout=2000 #micro-order.ribbon.OkToRetryOnAllOperations=true ##切换实例的重试次数 #micro-order.ribbon.MaxAutoRetriesNextServer=2 ##对当前实例的重试次数 当 Eureka 中可以找到服务,但是服务连不上时将会重试 #micro-order.ribbon.MaxAutoRetries=2 ##配置负载均衡 #micro.order.ribbon.NFLoadBalancerRuleClassName=com.netflix.loadbalancer.RandomRule #micro-order.ribbon.NFLoadBalancerPingClassName=com.netflix.loadbalancer.PingUrl

2.2 代码配置

2.2.1. 使用@RibbonClients 加载针对某一个服务的ribbon配置

这个配置类只针对 micro-order 服务,微服务系统里面有很多服务,这就可以区别化配置。

/* * 这个是针对 micro-order服务的 ribbon配置 * */ @Configuration @RibbonClients(value = { @RibbonClient(name = "micro-order",configuration = RibbonLoadBalanceMicroOrderConfig.class) }) // 也可以这样,只加载一个针对某个服务的ribbon配置 //@RibbonClient(name = "micro-order",configuration = RibbonLoadBalanceMicroOrderConfig.class public class LoadBalanceConfig { }
2.2.2. 配置 configuration

配置类的时候,一定要注意,配置类不能陪@ComponentScan 注解扫描到,如果被扫描到了则该配置类就是所有服务共用的配置了。

/* * 这个类最好不要出现在启动类的@ComponentScan扫描范围 * 如果出现在@ComponentScan扫描访问,那么这个配置类就是每个服务共用的配置了 * */ @Configuration public class RibbonLoadBalanceMicroOrderConfig { // @RibbonClientName private String name = "micro-order"; @Bean @ConditionalOnClass public IClientConfig defaultClientConfigImpl() { DefaultClientConfigImpl config = new DefaultClientConfigImpl(); config.loadProperties(name); config.set(CommonClientConfigKey.MaxAutoRetries,2); config.set(CommonClientConfigKey.MaxAutoRetriesNextServer,2); config.set(CommonClientConfigKey.ConnectTimeout,2000); config.set(CommonClientConfigKey.ReadTimeout,4000); config.set(CommonClientConfigKey.OkToRetryOnAllOperations,true); return config; } /* * 判断服务是否存活 * 不建议使用 * */ // @Bean // public IPing iPing() { // //这个实现类会去调用服务来判断服务是否存活 // return new PingUrl(); // } // 配置负载均衡,默认是轮训 @Bean public IRule ribbonRule() { //线性轮训 new RoundRobinRule(); //可以重试的轮训 new RetryRule(); //根据运行情况来计算权重 new WeightedResponseTimeRule(); //过滤掉故障实例,选择请求数最小的实例 new BestAvailableRule(); return new RandomRule(); } }

3.Ribbon 单独使用

Ribbon 是一个独立组件,可以脱离 springcloud 使用的.

有这两个jar包就可以

image.png

AI大模型学习福利

作为一名热心肠的互联网老兵,我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

一、全套AGI大模型学习路线

AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获取

二、640套AI大模型报告合集

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

三、AI大模型经典PDF籍

随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。


因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

四、AI大模型商业化落地方案

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 22:15:31

揭秘量子时代下的安全审计:MCP SC-400实战应用的5个关键步骤

第一章:MCP SC-400量子安全审计的演进与挑战随着量子计算技术的快速发展,传统加密体系面临前所未有的破解风险。MCP SC-400作为新一代量子安全审计标准,旨在应对后量子时代的信息安全挑战,确保关键基础设施在量子攻击下的数据完整…

作者头像 李华
网站建设 2026/4/18 8:43:59

Obsidian美化资源快速下载与使用指南

Obsidian美化资源快速下载与使用指南 【免费下载链接】awesome-obsidian 🕶️ Awesome stuff for Obsidian 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-obsidian 当你在Obsidian中投入大量时间整理知识时,一个美观舒适的工作环境就显得…

作者头像 李华
网站建设 2026/4/18 13:35:16

为什么你的量子模拟结果总出错?深度解析VSCode Jupyter内核配置陷阱

第一章:VSCode Jupyter 的量子模拟结果在 VSCode 中结合 Jupyter Notebook 进行量子计算模拟,已成为科研与教学中的高效实践方式。通过安装 Python 扩展与 Jupyter 插件,用户可在本地环境中直接编写和运行量子电路代码,并可视化其…

作者头像 李华
网站建设 2026/4/18 7:51:26

E-Hentai Viewer:解锁iOS设备上专业漫画阅读的全新体验

E-Hentai Viewer:解锁iOS设备上专业漫画阅读的全新体验 【免费下载链接】E-HentaiViewer 一个E-Hentai的iOS端阅读器 项目地址: https://gitcode.com/gh_mirrors/eh/E-HentaiViewer E-Hentai Viewer是一款专为iOS设备设计的专业漫画阅读器应用,让…

作者头像 李华
网站建设 2026/4/18 7:35:27

手把手教你部署Qiskit项目,全面掌握VSCode量子开发工作流

第一章:VSCode Qiskit 的项目部署在量子计算开发中,使用 Visual Studio Code(VSCode)结合 Qiskit 框架进行项目部署是一种高效且灵活的实践方式。通过合理的环境配置与工具集成,开发者能够快速构建、模拟和运行量子电路…

作者头像 李华
网站建设 2026/4/18 8:24:26

5个理由告诉你为什么TinyML正在改变你的生活

你是否曾经想过,为什么你的智能手环能够准确计算步数?为什么智能家居设备能听懂你的语音指令?这一切的背后,都离不开一个正在悄然改变世界的小技术——TinyML。想象一下,在只有指甲盖大小的芯片上运行AI模型&#xff0…

作者头像 李华