SpringCloud 2021.0.9 OpenFeign 与 circuitbreaker-resilience4j 使用示例

背景

OpenFeign是微服务中服务远程调用组件。
circuitbreaker 是断路器的抽象接口。
resilience4j是断路器的一种实现。

在服务间远程调用过程中,为了避免服务雪崩,需要设置失败保护机制,当下游服务超时或者不可用时,上游服务可以快速返回,同时下游服务会降级,上游服务短时间不去请求下游服务。

实现远程调用

服务提供者

服务提供者就是正常的SpringBoot项目,为了让服务调用者可以请求该服务,需要将服务信息注册到Consul注册中心。

1依赖如下:

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-config</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-discovery</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-circuitbreaker-resilience4j</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies>

2配置如下:

spring:application:name: system-applicationcloud:consul:discovery:service-name: ${spring.application.name}instance-id: system-servicehost: localhostport: 8500config:format: yamldata-key: systemenabled: truewatch:enabled: truewait-time: 5config:import: optional:consul:${spring.cloud.consul.host}:${spring.cloud.consul.port}/testhello:name

3还需要自己实现一个普通controller。

启动服务提供者,打开consul控制台,服务成功注册即可。

服务消费

1 添加依赖

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-config</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-discovery</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-circuitbreaker-resilience4j</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies>

相比服务提供者,多了一个断路器的依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-circuitbreaker-resilience4j</artifactId></dependency>

2 配置:

spring:application:name: portal-applicationcloud:consul:discovery:service-name: ${spring.application.name}instance-id: portal-servicehost: localhostport: 8500config:import: optional:consul:${spring.cloud.consul.host}:${spring.cloud.consul.port}feign:circuitbreaker:enabled: true
#  client:
#    config:
#      default:
#        connectTimeout: 1000
#        readTimeout: 1000server:port: 8081

配置文件中只添加如下配置,用于打开circuitbreaker。
feign:
circuitbreaker:
enabled: true

3 配置断路器, 这里配置了1ms的超时。

@Configuration
public class BreakerConfig {@Beanpublic Customizer<Resilience4JCircuitBreakerFactory> defaultCustomizer() {return factory -> factory.configureDefault(id -> new Resilience4JConfigBuilder(id).timeLimiterConfig(TimeLimiterConfig.custom().timeoutDuration(Duration.ofMillis(1)).build()).circuitBreakerConfig(CircuitBreakerConfig.ofDefaults()).build());}
}

4 实现FeignClient调用,主要是加入fallback逻辑,用于失败后的处理

@FeignClient(name ="system-application",  fallback = UserClient.Fallback.class)
@Component
public interface UserClient {@GetMapping("")String getName();@Componentstatic class Fallback implements UserClient {@Overridepublic String getName() {return "00000000000000000000000";}}
}

至此,基本的Demo已经完成。

启动服务消费者,访问feignClient的接口,发现返回了fallback类中配置的信息。证明断路器配置起作用。

除了断路器的配置外,如下的配置和断路器无关,支持配置了http请求的超时时间,如果超时,会报错,不会触发Fallback。

  client:config:default:connectTimeout: 1000readTimeout: 1000

总结

  1. 加入断路器依赖
  2. feign.circuitbreaker.enabled: true 开启断路器
  3. 注入Resilience4JConfigBuilder

以上三步在服务调用方实现。

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

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

相关文章

Eureka-搭建Eureka步骤

简介&#xff1a; Eureka是Netflix开发的服务发现框架&#xff0c;本身是一个基于REST的服务&#xff0c;主要用于定位运行在AWS域中的中间层服务&#xff0c;以达到负载均衡和中间层服务故障转移的目的。SpringCloud将它集成在其子项目spring-cloud-netflix中&#xff0c;以实…

【OTA】STM32新能源汽车OTA技术ymodem协议PC串口升级过程

【OTA】STM32新能源汽车OTA技术ymodem协议PC串口升级过程 文章目录 前言一、实验工具1.串口USB线——烧录APP2生成的BIN文件2.STLINK——烧录BOOT代码和APP1代码3.烧录工具——将BIN文件烧录到单片机中4.FLYMCU——清除芯片FLASH 二、硬件绘制1.原理图2.PCB 三、软件配置1.BOOT…

Github 2024-04-13 开源项目日报 Top9

根据Github Trendings的统计,今日(2024-04-13统计)共有9个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目2C++项目2Jupyter Notebook项目2TypeScript项目1Cuda项目1非开发语言项目1GoogleTest - Google测试和模拟框架 创建周期:3181 天开发…

订单状态及其转换

目录 新建状态&#xff08;Created&#xff09;/待处理&#xff08;Pending&#xff09; 待支付&#xff08;Pending Payment&#xff09; 支付确认中&#xff08;Payment Processing&#xff09; 支付成功&#xff08;Paid&#xff09; 处理中&#xff08;Processing&…

【2024-03-14】Spring中基于注解和AOP的结合实现(改造系统中的原有AOP鉴权)

业务需求 改造系统中的原先写的通过表达式拦截实现的鉴权功能。 原有逻辑 没有注释&#xff08;啊啊啊啊&#xff09;。 花费工时7.5小时。 步骤如下&#xff1a; 获取Header头参数。校验Header头的必要参数。通过Header中获取的参数&#xff0c;查询数据库入口表信息。通过…

【软件设计师知识点】三、数据结构

文章目录 逻辑结构与物理结构线性结构线性表顺序存储链式存储栈和队列栈和队列的基本性质循环队列双端队列栈与队列的应用串非线性结构数组矩阵树与二叉树树的基本术语二叉树的性质特殊二叉树<

gateway的授权思考

gateway的授权思考 1、看了一下若依的cloud项目。 登录&#xff1a;是传将authoration 这个token和当前用户绑定&#xff0c;然后放在redis.在登录的时候&#xff0c;也将相关的信息&#xff0c;比如校验了一下。不通过就不通过。 Override public OAuth2ClientDO validOAuth…

2024.4.14 Python爬虫复习Day02

day02_web服务器优化 注意: 需要提前把资料中source目录复制到当前项目中 1.回顾基本web服务器 # 1.导包(fastapi和uvicorn) from fastapi import FastAPI from fastapi import Response import uvicorn# 2.创建对象(注意:创建对象的时候,类名后加小括号()) api FastAPI()# 3…

jenkins通过pipeline部署springboot项目

部署方案&#xff1a; 1、springboot项目不保存部署的pipeline或dockerfile构建脚本等与部署相关的问文件&#xff0c;业务项目只需关心业务&#xff0c;能够正常构建为jar包即可 2、新建一个代码仓库&#xff0c;用于保存项目需要构建的Jenkinsfile 3、jenkins配置pipeline地址…

李廉洋;4.14黄金原油最新资讯,下周一盘走势分析及策略。

现货黄金昨日一度创下2430美元/盎司的历史新高&#xff0c;但随后一路回调至2344美元附近&#xff0c;较历史高位回落近百美元。分析师表示这是因为投资者在被视为过度的价格反弹中获利了结并离场所致。金融机构MKS PAMP SA的金属策略主管Nicky Shiels表示&#xff1a;“随着大…

基于Docker构建CI/CD工具链(六)使用Apifox进行自动化测试

添加测试接口 在Spring Boot Demo项目里实现一个简单的用户管理系统的后端功能。具体需求如下&#xff1a; 实现了一个RESTful API&#xff0c;提供了以下两个接口 &#xff1a; POST请求 /users&#xff1a;用于创建新的用户。GET请求 /users&#xff1a;用于获取所有用户的列…

计算机网络技术-RIP、0SPF和BGP协议的工作原理和应用

目录 RIP (Routing Information Protocolv&#xff09;路由信息协议OSPF(Open Shortest Path First) 开放式最短路径优先BGP( Border Gateway Protocol)边界网关协议 RIP (Routing Information Protocolv&#xff09;路由信息协议 RIP协议 是 TCP/IP环境中开发的第一个路由选择…

微信小程序相关

目录 一、WXML与HTML的异同 二、WXSS和CSS的异同 三、微信小程序主要目录和文件的作用 四、小程序的双向绑定和vue的异同 五、微信小程序有哪些传值(传递数据)方法 六、小程序的生命周期函数 APP生命周期 Page生命周期 Component生命周期 七、小程序的原理 八、小程…

STC89C52学习笔记(十一)

STC89C52学习笔记&#xff08;十一&#xff09; 综述&#xff1a;本文讲述了直流电机以及PWM调速。 一、直流电机 1、特点 &#xff08;1&#xff09;直流电机能将电能转化位机械能。 &#xff08;2&#xff09;直流电机有两个电极&#xff0c;电极正接时&#xff0c;电机…

【核心完整复现】基于目标级联法的微网群多主体分布式优化调度

1 主要内容 之前发布了华电学报的复现程序《基于目标级联法的微网群多主体分布式优化调度》&#xff0c;具体链接为【防骗版】基于目标级联法的微网群多主体分布式优化调度&#xff0c;虽然对模型及结果进行了复现&#xff0c;但是部分模型细节和参数并没有完全实现&#xff0…

【leetcode面试经典150题】47. 最长连续序列(C++)

【leetcode面试经典150题】专栏系列将为准备暑期实习生以及秋招的同学们提高在面试时的经典面试算法题的思路和想法。本专栏将以一题多解和精简算法思路为主&#xff0c;题解使用C语言。&#xff08;若有使用其他语言的同学也可了解题解思路&#xff0c;本质上语法内容一致&…

2024长三角快递物流高质量创新发展论坛

2024长三角快递物流供应链与技术装备展览会&#xff08;杭州&#xff09; 2024年7月8-10日 | 杭州国际博览中心 指导单位&#xff1a;浙江省邮政管理局 中国快递协会 主办单位&#xff1a;浙江省快递行业协会 联合主办&#xff1a;上海市快递协会 江苏省快递协会 安徽省快递…

Ajax跨域请求

解决 AJAX 跨域请求的方法有几种。跨域请求指的是通过 AJAX 在不同域名、端口或协议下进行的请求&#xff0c;由于浏览器的安全策略限制&#xff0c;这些请求可能会被阻止。以下是一些常见的解决方法&#xff1a; 1、使用服务器代理 在你的服务器上创建一个代理&#xff0c;将…

ubuntu22下使用vscode调试redis7源码环境搭建

ubuntu22下使用vscode调试redis7源码环境搭建 ##vscode launch.json配置文件 {// 使用 IntelliSense 了解相关属性。 // 悬停以查看现有属性的描述。// 欲了解更多信息&#xff0c;请访问: https://go.microsoft.com/fwlink/?linkid830387"version": "0.2.0&…

【DL水记】循环神经网络RNN的前世今生,Transformer的崛起,Mamba模型

文章目录 RNN网络简介传统RNN网络结构RNN的分类 长-短期记忆网络 (LSTM)GRU网络横空出世的Transformer网络Self-AttentionVisionTransformer Mamba模型Reference: RNN网络简介 “当人类接触新事物时&#xff0c;他们不会从头开始思考。就像你在阅读这篇文章时&#xff0c;你会根…