Spring Boot集成Resilience4J实现断路器功能
创作时间:
作者:
@小白创作中心
Spring Boot集成Resilience4J实现断路器功能
引用
CSDN
1.
https://blog.csdn.net/dot_life/article/details/140882444
什么是Resilience4J?
Netflix Hystrix 断路器是 Spring Cloud 中最早就开始支持的一种服务调用容错解决方案,但是目前的 Hystrix 已经处于维护模式了,虽然这并不影响已经上线的项目,并且在短期内,你甚至也可以继续在项目中使用 Hystrix 。但是长远来看,处于维护状态的 Hystrix 走下历史舞台只是一个时间问题,特别是在 Spring Cloud Greenwich 版中,官方已经给出了 Hystrix 的建议替代方案。如下图:
Resilience4j 是 Spring Cloud Greenwich 版推荐的容错解决方案,它是一个轻量级的容错库,受 Netflix Hystrix 的启发而设计,它专为 Java 8 和函数式编程而设计。 Resilience4j 非常轻量级,因为它的库只使用 Vavr (以前称为 Javaslang ),它没有任何其他外部库依赖项。相比之下, Netflix Hystrix 对Archaius 具有编译依赖性,这导致了更多的外部库依赖,例如 Guava 和 Apache Commons 。而如果使用Resilience4j,你无需引用全部依赖,可以根据自己需要的功能引用相关的模块即可。 Resilience4j 也提供了一系列增强微服务可用性的功能,主要功能如下:
- 断路器
- 限流
- 基于信号量的隔离
- 缓存
- 限时
- 请求重试
今天我么主要讲解断路器是如何实现的?
实验工程
实验目的
实现断路器功能
pom.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>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.2.1</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>resilience4j</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>io.github.resilience4j</groupId>
<artifactId>resilience4j-spring-boot3</artifactId>
<version>2.0.2</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
</project>
controller
package com.et.resilience4j.controller;
import com.et.resilience4j.model.Activity;
import io.github.resilience4j.circuitbreaker.annotation.CircuitBreaker;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
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;
@Slf4j
@RequestMapping("/activity")
@RestController
public class ActivityController {
private RestTemplate restTemplate;
private final String BORED_API = "http://www.liuhaihua.cn/api/activity";
public ActivityController(RestTemplate restTemplate) {
this.restTemplate = restTemplate;
}
@GetMapping
@CircuitBreaker(name = "randomActivity", fallbackMethod = "fallbackRandomActivity")
public String getRandomActivity() {
ResponseEntity<Activity> responseEntity = restTemplate.getForEntity(BORED_API, Activity.class);
Activity activity = responseEntity.getBody();
log.info("Activity received: " + activity.getActivity());
return activity.getActivity();
}
public String fallbackRandomActivity(Throwable throwable) {
return "fail to read a Activity from HBLOG";
}
}
entity
package com.et.resilience4j.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/* sample message
{
"activity": "Start a family tree",
"type": "social",
"participants": 1,
"price": 0,
"link": "https://en.wikipedia.org/wiki/Family_tree",
"key": "6825484",
"accessibility": 1
}*/
@NoArgsConstructor
@AllArgsConstructor
@Data
public class Activity {
private String activity;
private String type;
private String link;
private String key;
private Integer participants;
private Double price;
private Double accessibility;
}
DemoApplication.java
package com.et.resilience4j;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
application.yaml
spring:
application.name: resilience4j-demo
jackson.serialization.indent_output: true
management:
endpoints.web.exposure.include:
- '*'
endpoint.health.show-details: always
health.circuitbreakers.enabled: true
resilience4j.circuitbreaker:
configs:
default:
registerHealthIndicator: true
slidingWindowSize: 10
minimumNumberOfCalls: 5
permittedNumberOfCallsInHalfOpenState: 3
automaticTransitionFromOpenToHalfOpenEnabled: true
waitDurationInOpenState: 5s
failureRateThreshold: 50
eventConsumerBufferSize: 10
以上只是一些关键代码,所有代码请参见下面代码仓库
代码仓库
测试
- 启动Spring Boot应用工程
- 访问http://127.0.0.1:8080/activity
- 返回
fail to read a Activity from HBLOG
引用
- Cloud Native Applications
热门推荐
工控机是什么?如何在不同行业中使用?
民政部发布个人求助平台名单,会对大病筹款带来什么影响?
11 个洋葱品种及最佳烹饪方法
【第六屆信誼幼兒文學獎】红公鸡
公租房变更承租人规定及申请条件详解
宝宝第一次微笑:不仅仅是可爱的瞬间,更是社交发展的里程碑
甘草的功效、用法与副作用全解析:两款甘草茶食谱分享
自制炸油条,快乐享受美食(手把手教你,轻松DIY好吃炸油条)
颅咽管瘤症状:这12个常见的临床表现!
“距离产生美”——掌握保持安全车距的秘诀
专业显卡和游戏显卡究竟有啥区别 吵了10年的问题有了答案
2025年意甲球员转会市场趋势分析及未来发展预测报告
草莓的水分管理技巧(浇水时间、水量、频率应该如何)
黄金期货和黄金期权有什么区别,如何区分两者的区别?
2.52亿年前,这里是远古生命的"避难所"
武汉出发:海南岛深度自驾游终极攻略与路线指南
玉米黄素功效有哪些?副作用、摄入量、食物来源一次了解!
心脏功能衰竭,与喝水有关?医生:心脏不好的人,这4水建议少喝
FPGA能做什么?比单片机厉害吗?
如何选择合适的听诊器
天干地支的刑冲合害等作用关系
古代表达相思之情的经典诗句
重塑说话技巧:针对口吃的功能性训练与实用策略
上海离婚流程及赔偿标准详解
家长行动起来!用健康方式助力孩子快乐成长!
羊肉有股骚味要警惕了
春回大地万鸟翔集 绿色吉林生机勃勃
如何查看docker服务状态
如何查看docker关闭原因
音乐为何能唤起记忆?歌曲背后的媒介记忆