高可用开源库之 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

相关推荐
懂得节能嘛.1 分钟前
【动态配置中心】Java+Redis构建动态配置中心
java·开发语言·redis
专注于大数据技术栈2 分钟前
Java中JDK、JRE、JVM概念
java·开发语言·jvm
YuanlongWang6 分钟前
C# 基础——值类型与引用类型的本质区别
java·jvm·c#
Kay_Liang30 分钟前
大语言模型如何精准调用函数—— Function Calling 系统笔记
java·大数据·spring boot·笔记·ai·langchain·tools
自由的疯1 小时前
Java 如何学习Docker
java·后端·架构
自由的疯1 小时前
Java Docker本地部署
java·后端·架构
007php0071 小时前
猿辅导Java面试真实经历与深度总结(二)
java·开发语言·python·计算机网络·面试·职场和发展·golang
摇滚侠1 小时前
Spring Boot 3零基础教程,WEB 开发 内容协商机制 笔记34
java·spring boot·笔记·缓存
一勺菠萝丶1 小时前
在 macOS 上用 Docker 为 Java 后端 & 常见开发需求搭建完整服务(详尽教程)
java·macos·docker
顾漂亮1 小时前
JVM底层攻坚
java·jvm·spring