Resilience4j是专为Java8和函数式编程设计的容错库

栏目: Java · 发布时间: 6年前

内容简介:Netflix OSS的Hystrix替代品与Netflix Hystrix的一些差异:

Netflix OSS的Hystrix替代品 Resilience4j是一个轻量级容错库,受 Netflix Hystrix 启发,但专为 Java 8和函数式编程而设计。轻量级,因为库只使用 Vavr(以前称为Javaslang) ,它没有任何其他外部库依赖项。相比之下,Netflix Hystrix对 Archaius 具有编译依赖性, Archaius 具有更多外部库依赖性,例如Guava和Apache Commons Configuration。使用Resilience4j,你不必全押,你可以选择你需要的东西。

与Netflix Hystrix的一些差异:

  • 在Hystrix中,对外部系统的调用必须包含在HystrixCommand中。相比之下,本库包提供了高阶函数(装饰器),以通过 断路器 ,速率限制器或隔板增强任何函数接口,lambda表达式或方法引用。此外,库提供的装饰器来重试失败的调用或缓存调用结果。您可以在任何函数接口、lambda表达式或方法引用上堆叠多个装饰器。这意味着,您可以将隔板Bulkhead,RateLimiter和Retry装饰器与CircuitBreaker装饰器结合使用。优点是您可以选择所需的装饰器,而不是其他任何东西。任何修饰函数都可以使用CompletableFuture或RxJava同步或异步执行。
  • 默认情况下,Hystrix将执行结果存储在10个1秒的窗口桶中。如果传递1秒窗口桶,则会创建一个新桶,并删除最旧的桶。该库将执行结果存储在Ring Bit Buffer中,而没有统计滚动时间窗口。成功的呼叫存储为0位,失败的呼叫存储为1位。Ring Bit Buffer具有可配置的固定大小,并将这些位存储在long []数组中,与布尔数组相比,这节省了内存。这意味着Ring Bit Buffer只需要一个包含16个长(64位)值的数组来存储1024个调用的状态。优点是这个CircuitBreaker可以为低频和高频后端系统提供开箱即用的功能,因为在传递时间窗口时不会丢弃执行结果。
  • Hystrix仅在处于半开状态时执行单次执行,以确定是否关闭CircuitBreaker。该库允许执行可配置数量的执行,并将结果与​​可配置阈值进行比较,以确定是否关闭CircuitBreaker。
  • 该库提供自定义RxJava运算符来装饰任何Observable或Flowable使用Circuit Breaker,Bulkhead或Ratelimiter。
  • Hystrix和此库发出一系列事件,这些事件对系统操作员有用,可监控有关执行结果和延迟的指标。

以上所述就是小编给大家介绍的《Resilience4j是专为Java8和函数式编程设计的容错库》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

能量分析攻击

能量分析攻击

Stefan Mangard、Elisabeth Oswald、Thomas Popp / 科学出版社 / 2010-8 / 58.00元

《能量分析攻击》可以作为密码学、电子工程、信息安全等专业的教材,也可以供相关专业人员参考。能量分析攻击旨在通过分析密码设备的能量消耗这一物理特性来恢复设备内部的秘密信息,这种基于实现特性的密码分析对广泛应用的各类密码模块的实际安全性造成了严重威胁,《能量分析攻击》是关于能量分析攻击的综合性专著,系统阐述了能量分析攻击的基本原理、技术方法以及防御对策的设计与分析。一起来看看 《能量分析攻击》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具