高可用开源库之 Hystrix-01-概览

高可用系列

高可用开源库之 Hystrix-01-概览

高可用开源库之 Hystrix-02-聊一聊

高可用开源库之 Resilience4j-01-Netflix Hystrix 的替代者 overview

高可用开源库之 Resilience4j-02-chat 聊一聊

高可用开源库之 阿里流控组件 sentinel-01-overview 面向云原生微服务的高可用流控防护组件

高可用开源库之 阿里流控组件 sentinel-02-chat

Hystrix

Hystrix 是一个延迟和容错库,旨在隔离对远程系统、服务和第三方库的访问点,防止级联故障, 并在不可避免出现故障的复杂分布式系统中恢复能力。

特性

  • 延迟和容错

停止级联故障。回退和优雅的退化。快速失败和快速恢复。

带断路器的线程和信号量隔离。

  • 实时操作

实时监控和配置更改。观察服务和财产变化立即生效,因为他们分散在一个舰队。

警惕,做出决定,影响改变,在几秒钟内看到结果。

  • 并发性

并行执行。并发性意识到请求缓存。通过请求崩溃自动批处理。

快速开始

jar 引入

xml 复制代码
<dependency>
    <groupId>com.netflix.hystrix</groupId>
    <artifactId>hystrix-core</artifactId>
    <version>1.5.12</version>
</dependency>

HystrixCommand

HystrixCommand 的最简单实现:

java 复制代码
public class CommandHelloWorld extends HystrixCommand<String> {

    private final String name;

    public CommandHelloWorld(String name) {
        super(HystrixCommandGroupKey.Factory.asKey("ExampleGroup"));
        this.name = name;
    }

    @Override
    protected String run() {
        // a real example would do work like a network call here
        return "Hello " + name + "!";
    }
}

ps: 还有一个等效的开始类,HystrixObservableCommand 此处省去不谈。

同步执行

java 复制代码
String s = new CommandHelloWorld("World").execute();

异步执行

  • Future
java 复制代码
Future<String> fs = new CommandHelloWorld("World").queue();
String s = fs.get();

监听

实现方式

java 复制代码
Observable<String> ho = new CommandHelloWorld("World").observe();
// or Observable<String> co = new CommandHelloWorld("World").toObservable();

监听方式

java 复制代码
ho.subscribe(new Action1<String>() {

    @Override
    public void call(String s) {
         // value emitted here
    }

});

实际案例

  • testObservable()
java 复制代码
@Test
public void testObservable() throws Exception {
    Observable<String> fWorld = new CommandHelloWorld("World").observe();
    Observable<String> fBob = new CommandHelloWorld("Bob").observe();
    // blocking
    assertEquals("Hello World!", fWorld.toBlocking().single());
    assertEquals("Hello Bob!", fBob.toBlocking().single());
    // non-blocking
    // - this is a verbose anonymous inner-class approach and doesn't do assertions
    fWorld.subscribe(new Observer<String>() {
        @Override
        public void onCompleted() {
            // nothing needed here
        }
        @Override
        public void onError(Throwable e) {
            e.printStackTrace();
        }
        @Override
        public void onNext(String v) {
            System.out.println("onNext: " + v);
        }
    });
    // non-blocking
    // - also verbose anonymous inner-class
    // - ignore errors and onCompleted signal
    fBob.subscribe(new Action1<String>() {
        @Override
        public void call(String v) {
            System.out.println("call: " + v);
        }
    });
}
  • 输出日志

    SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
    SLF4J: Defaulting to no-operation (NOP) logger implementation
    SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.

    onNext: Hello World!
    call: Hello Bob!

替代方案

resilience4j

相关推荐
forestsea20 分钟前
【Java 解释器模式】实现高扩展性的医学专家诊断规则引擎
java·人工智能·设计模式·解释器模式
陈小于23 分钟前
springboot集成shiro和前后端分离配置
java·spring boot·后端
不修×蝙蝠37 分钟前
数据结构--数组实现栈和队列
java·数据结构·数组··队列
信息化未来42 分钟前
odoo17 档案管理之翻译2
java·服务器·前端
清山博客1 小时前
Java将PDF保存为图片
java·开发语言·pdf
life10241 小时前
pdf文档动态插入文字水印,45度角,旋转倾斜,位于文档中央,多行水印可插入中文
java·pdf·水印
归鸿铭1 小时前
Html 转pdf
java·pdf·html
lix的小鱼1 小时前
Scala之Array数组
java·开发语言·后端·python·scala
计算机徐师兄1 小时前
Java基于SSM框架的校园综合服务小程序【附源码、文档】
java·微信小程序·小程序·校园综合服务小程序·java校园综合服务小程序·校园综合服务微信小程序
柔弱女子爱java1 小时前
XML文件(超详细):XML文件概念、作用、写法、如何用程序解析XML、写入XML、dom4j框架、DTD文档、schema文档
xml·java·开发语言·后端