Spring Cloud Circuit Breaker 使用示例
2024-10-20 16:10:12
Spring Cloud Circuit Breaker 使用示例
作者: Grey
原文地址:
博客园:Spring Cloud Circuit Breaker 使用示例
CSDN:Spring Cloud Circuit Breaker 使用示例
说明
Spring Cloud Circuit breaker提供了一个跨越不同断路器实现的抽象。它提供了一个一致的API,可以在你的应用程序中使用,允许你的开发者选择最适合你的应用程序需求的断路器实现。
它还支持的实现有如下几种
完整代码
spring-cloud-circuit-breaker-usage
环境
JDK 1.8+
Maven 3.5+
Spring Boot 版本:2.7.5
Spring Cloud 版本:2021.0.5
项目结构和说明
- spring-cloud-circuit-breaker-usage:父项目名称
- server : 服务端端模块
- src/
- pom.xml
- client : 客户端模块
- src/
- pom.xml
- pom.xml:父项目 pom 配置
- server : 服务端端模块
代码说明
服务端需要引入如下依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
然后暴露一个简单服务
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import reactor.core.publisher.Mono;
@RestController
public class BookController {
@RequestMapping(value = "/recommended")
public Mono<String> readingList() {
return Mono.just("book1,book2,book3");
}
}
暴露端口
server.port=8090
客户端的配置也很简单,核心在ReactiveCircuitBreaker
的初始化,客户端的依赖如下
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-circuitbreaker-reactor-resilience4j</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.cloud.client.circuitbreaker.ReactiveCircuitBreaker;
import org.springframework.cloud.client.circuitbreaker.ReactiveCircuitBreakerFactory;
import org.springframework.stereotype.Service;
import org.springframework.web.reactive.function.client.WebClient;
import reactor.core.publisher.Mono;
@Service
public class BookService {
private static final Logger LOG = LoggerFactory.getLogger(BookService.class);
private final WebClient webClient;
private final ReactiveCircuitBreaker readingListCircuitBreaker;
public BookService(ReactiveCircuitBreakerFactory circuitBreakerFactory) {
this.webClient = WebClient.builder().baseUrl("http://localhost:8090").build();
this.readingListCircuitBreaker = circuitBreakerFactory.create("recommended");
}
public Mono<String> readingList() {
return readingListCircuitBreaker.run(webClient.get().uri("/recommended").retrieve().bodyToMono(String.class), throwable -> {
LOG.warn("Error making request to book service", throwable);
return Mono.just("local store book");
});
}
}
如果需要配置一些熔断条件,则做如下设置即可
CircuitBreakerConfig circuitBreakerConfig = CircuitBreakerConfig.custom()
.failureRateThreshold(50)
.waitDurationInOpenState(Duration.ofMillis(1000))
.slidingWindowSize(2)
.build();
TimeLimiterConfig timeLimiterConfig = TimeLimiterConfig.custom()
.timeoutDuration(Duration.ofSeconds(4))
.build();
this.readingListCircuitBreaker = circuitBreakerFactory.configureDefault(
id -> new Resilience4JConfigBuilder(id)
.timeLimiterConfig(timeLimiterConfig)
.circuitBreakerConfig(circuitBreakerConfig)
客户端暴露一个接口用于测试
@RestController
public class ReadingController {
private final BookService bookService;
public ReadingController(BookService bookService) {
this.bookService = bookService;
}
@RequestMapping("/to-read")
public Mono<String> toRead() {
return bookService.readingList();
}
}
客户端设置端口
server.port=8080
接下来,启动服务端,然后启动客户端,用 Postman 或者其他相关工具访问: http://localhost:8080/to-read
然后把服务端停止,模拟服务中断,再次访问: http://localhost:8080/to-read
显示了降级后的内容。
参考文档
spring-cloud-circuitbreaker-demo
Spring Cloud Circuit Breaker Guide
Quick Guide to Spring Cloud Circuit Breaker
最新文章
- 关于Linux下转换oracle字符集
- Debian8.3安装flash插件,备用~~~
- 一场属于HTML5守望者的盛宴——记图灵参加HTML5峰会
- pycharm快捷键、常用设置、包管理
- <;select>;的下拉样式
- ASP.NET MVC 下拉框的传值的两种方式
- sqlite 的比较等运算是根据不同的值而不同的,并不是根据的字段类型,因为 sqlite 是弱类型字段
- Logger.getLogger和LogFactory.getLog的区别
- uC/OS-II源码分析
- lecode Interleaving String
- JS 数组扩展函数--求起始项到终止项和
- 开发框架(WinForm)3
- [转] (CQRS)命令和查询责任分离架构模式(一) 之 什么是CQRS
- uva 1151最小生成树
- service层报错找不到方法Invalid bound statement (not found)
- [mysql5.6] 主从更换ip之后重新建立同步
- mysql连接失败HikariPool错误
- mac配置supervisor
- azkaban 配置邮件
- JavaScript中的Date对象在IOS中的“大坑”
热门文章
- 不当使用 union all 导致的SQL解析时间过长的问题优化
- docker_命令总结
- 如何结合整洁架构和MVP模式提升前端开发体验(三) - 项目工程化配置、规范篇
- aardio + .NET 快速开发独立 EXE 程序,可防 ILSpy 反编译
- [C/C++]C语言-踩坑记录
- Python数据科学手册-Pandas:层级索引
- Django提交时报错
- ProxySQL配置之MySQL服务器配置
- DirectPV-----文章内容有待进一步实践完善
- Elasticsearch:设置Elastic账户安全