Hystrix的隔离策略

目录

一、线程池隔离

二、信号量隔离

三、适用场景


Hystrix提供两种主要的隔离策略来控制服务之间的交互,防止系统中一个组件的失败影响到其他组件。分别是线程池隔离和信号量隔离。基本上大多数场景,都是使用线程池隔离的!

一、线程池隔离

这是Hystrix的默认隔离策略,也是推荐方式。在这种策略中,每一个依赖服务调用都在一个单独的线程中执行,这个线程从专门为每个Hystrix命令或服务依赖配置的线程池中获取。如果线程池已满,新的请求将会被立即拒绝,不会继续等待或阻塞调用者线程。

优点:

  • 提供了真正的任务隔离;如果依赖服务变得缓慢或无响应,只会影响到运行在同一线程池中的请求。
  • 可以限制并发调用的数量,避免系统过载。
import com.netflix.hystrix.HystrixCommand;
import com.netflix.hystrix.HystrixCommandGroupKey;
import com.netflix.hystrix.HystrixCommandProperties;
import com.netflix.hystrix.HystrixThreadPoolProperties;

public class RemoteServiceCommand extends HystrixCommand<String> {
    protected RemoteServiceCommand() {
        super(Setter.withGroupKey(HystrixCommandGroupKey.Factory.asKey("ExampleGroup"))
            .andThreadPoolPropertiesDefaults(HystrixThreadPoolProperties.Setter()
                .withCoreSize(10) // 核心线程数
                .withMaxQueueSize(5)) // 等待队列长度
            .andCommandPropertiesDefaults(HystrixCommandProperties.Setter()
                .withExecutionTimeoutInMilliseconds(1000)));
    }

    @Override
    protected String run() {
        // 远程服务调用
        return null;
    }
}

二、信号量隔离

信号量隔离使用Java的信号量来限制并发访问的数量,而不是在不同的线程中执行命令。当请求达到信号量计数的限制时,新的请求会被立即拒绝,而不会导致线程的创建或切换。

优点:

  • 开销较小,没有线程切换和创建的成本。
  • 适用于执行非常快但需要频繁访问的操作。

三、适用场景

  • 线程池隔离:适合99%场景,尤其是外部调用的场景,尤其是那些可能会慢或失败的服务(如外部API、数据库查询等)
  • 信号量:适合轻量级操作,不太可能导致长时间延迟的服务调用,如内存或缓存服务访问。
  • 8
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全真王重阳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值