当前位置: 首页 > news >正文

SpringCloud系列(33)--使用Hystrix进行通配服务降级

前言:在上一节中我们使用Hystrix进行了全局服务降级,但服务降级用的相关代码都写在了controller层中,与业务代码高度耦合了,所以本节内容则是关于如何使服务降级的相关代码与业务代码解耦。

1、在cloud-consumer-feign-hystrix-order80子模块下的service包下新建一个名为PaymentFallbackService的类

效果图:

2、修改cloud-consumer-feign-hystrix-order80子模块的PaymentFallbackService类
package com.ken.springcloud.service;import org.springframework.stereotype.Component;@Component
public class PaymentFallbackService implements PaymentHystrixService{@Overridepublic String paymentInfoOK(Integer id) {return "PaymentFallbackService fall back paymentInfoOK";}@Overridepublic String paymentInfoTimeOut(Integer id) {return "PaymentFallbackService fall back paymentInfoTimeOut";}}

3、修改cloud-consumer-feign-hystrix-order80子模块的PaymentHystrixService类
package com.ken.springcloud.service;import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;@Component
//这里@FeignClient里写的是指定要访问的微服务的名称,表示通过FeignClient去Eureka上面找名称为CLOUD-PROVIDER-HYSTRIX-PAYMENT的微服务的接口,PaymentFallbackService是负责服务降级处理的类,统一为当前接口的方法进行异常处理
@FeignClient(value = "CLOUD-PROVIDER-HYSTRIX-PAYMENT", fallback = PaymentFallbackService.class)
public interface PaymentHystrixService {//指明要调用的CLOUD-PROVIDER-HYSTRIX-PAYMENT的微服务的接口,这里调用的是PaymentController类里的/payment/hystrix/ok/{id}接口@GetMapping("/payment/hystrix/ok/{id}")public String paymentInfoOK(@PathVariable("id") Integer id);//指明要调用的CLOUD-PROVIDER-HYSTRIX-PAYMENT的微服务的接口,这里调用的是PaymentController类里的/payment/hystrix/timeout/{id}接口@GetMapping("/payment/hystrix/timeout/{id}")public String paymentInfoTimeOut(@PathVariable("id") Integer id);}

4、重启cloud-consumer-feign-hystrix-order80服务

效果图:

5、 在浏览器的地址栏里输入http://localhost:8080/consumer/payment/hystrix/ok/1通过调用这个接口查看服务消费者的全局服务降级功能是否正常运行

由图可知cloud-consumer-feign-hystrix-order80服务和cloud-provider-hystrix-payment8001正常运行

6、关停cloud-provider-hystrix-payment8001服务,然后重新在浏览器的地址栏里输入http://localhost:8080/consumer/payment/hystrix/ok/1通过调用这个接口查看在服务提供者宕机的情况下服务消费者的服务降级功能是否正常运行

效果图:

由图可知服务消费者在服务提供者宕机后走了PaymentFallbackService类的服务降级处理,让服务消费者在服务提供者不可用后也可以获取到提示信息从而使得服务消费者不会挂起、重试来占用资源从而耗死服务器

http://www.lryc.cn/news/574175.html

相关文章:

  • 前缀树进阶-经典案例详解
  • Ubuntu20.04安装录屏工具OBS
  • 【Leetcode】有效的括号、用栈实现队列、用队列实现栈
  • Spring Boot + Logback MDC 深度解析:实现全链路日志追踪
  • 从数据到洞察:UI前端如何利用大数据优化用户体验
  • 用Fiddler抓包工具优化API联调流程:与Postman、Wireshark协作实践分享
  • Zynq + FreeRTOS + YAFFS2 + SQLite3 集成指南
  • 在Ubuntu上设置Firefox自动化测试环境:指定Marionette端口号
  • SpringBoot+Vue自习室座位预约系统
  • Lamp和友点CMS一键部署脚本(Rocky linux)
  • 技术干货 | 深度解读GB/T 45086.1-2024 EMC部分关键项
  • Excel学习03
  • 如何在 Vue 应用中嵌入 ONLYOFFICE 编辑器
  • 零基础学习RabbitMQ(2)--Linux安装RabbitMQ
  • 16.数据聚合
  • 文章以及好用网站分享
  • [QMT量化交易小白入门]-六十六、加入评分阈值后,历史回测收益率达到74%
  • Matlab自学笔记六十:符号表达式的缩写和简化
  • <tauri><threejs><rust><GUI>基于tauri和threejs,实现一个3D图形浏览程序
  • WPF中MVVM和MVVMLight模式
  • 技术逐梦之旅:从C语言到Vue的成长之路
  • 【附源码】考试报名系统设计与实现+SpringBoot + Vue (前后端分离)
  • Java底层原理:深入理解类加载机制与反射
  • 开始读Learning PostgresSQL第二版
  • C# SolidWorks二次开发-实战2,解决SolidWorks2024转step文件名乱码问题
  • STM32和C++ 实现配置文件导入、导出功能
  • 【技术分享】XR技术体系浅析:VR、AR与MR的区别、联系与应用实践
  • 使用CloudFormation模板自动化AWS基础设施的部署
  • 【第二章:机器学习与神经网络概述】03.类算法理论与实践-(2)朴素贝叶斯分类器
  • Auto-GPT vs ReAct:两种智能体思路对决