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

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

内容简介: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和函数式编程设计的容错库》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

机器学习

机器学习

周志华 / 清华大学出版社 / 2016-1-1 / 88.00元

机器学习是计算机科学与人工智能的重要分支领域. 本书作为该领域的入门教材,在内容上尽可能涵盖机器学习基础知识的各方面。 为了使尽可能多的读者通过本书对机器学习有所了解, 作者试图尽可能少地使用数学知识. 然而, 少量的概率、统计、代数、优化、逻辑知识似乎不可避免. 因此, 本书更适合大学三年级以上的理工科本科生和研究生, 以及具有类似背景的对机器学 习感兴趣的人士. 为方便读者, 本书附录给出了一......一起来看看 《机器学习》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

MD5 加密
MD5 加密

MD5 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具