Hystrix基本概念及简单用法

本文介绍SpringCloud中Hystrix组件的作用与配置,包括如何实现接口调用过程中的熔断处理,防止级联故障。同时展示了具体的实现步骤和技术细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Hystrix基本概念

1、Spring Cloud调用接口过程

Spring Cloud 在接口调用上,大致会经过如下几个组件配合:

Feign ----->Hystrix —>Ribbon —>Http Client(apache http components 或者 Okhttp) 具体交互流程上,如下图所示:
在这里插入图片描述
(1)接口化请求调用当调用被@FeignClient注解修饰的接口时,在框架内部,将请求转换成Feign的请求实例feign.Request,交由Feign框架处理。
(2)Feign :转化请求Feign是一个http请求调用的轻量级框架,可以以Java接口注解的方式调用Http请求,封装了Http调用流程。

(3)Hystrix:熔断处理机制 Feign的调用关系,会被Hystrix代理拦截,对每一个Feign调用请求,Hystrix都会将其包装成HystrixCommand,参与Hystrix的流控和熔断规则。如果请求判断需要熔断,则Hystrix直接熔断,抛出异常或者使用FallbackFactory返回熔断Fallback结果;如果通过,则将调用请求传递给Ribbon组件。

(4)Ribbon:服务地址选择 当请求传递到Ribbon之后,Ribbon会根据自身维护的服务列表,根据服务的服务质量,如平均响应时间,Load等,结合特定的规则,从列表中挑选合适的服务实例,选择好机器之后,然后将机器实例的信息请求传递给Http Client客户端,HttpClient客户端来执行真正的Http接口调用;

(5)HttpClient :Http客户端,真正执行Http调用根据上层Ribbon传递过来的请求,已经指定了服务地址,则HttpClient开始执行真正的Http请求

2、Hystrix概念

Hystrix 是一个供分布式系统使用,提供延迟和容错功能,保证复杂的分布系统在面临不可避免的失败时,仍能有其弹性。

比如系统中有很多服务,当某些服务不稳定的时候,使用这些服务的用户线程将会阻塞,如果没有隔离机制,系统随时就有可能会挂掉,从而带来很大的风险。SpringCloud使用Hystrix组件提供断路器、资源隔离与自我修复功能。下图表示服务B触发了断路器,阻止了级联失败
在这里插入图片描述

feign结合Hystrix使用

1、pom中添加依赖

		<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
        </dependency>

        <!--hystrix依赖,主要是用  @HystrixCommand -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>

        <!--服务注册-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--服务调用-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

2、在配置文件中添加hystrix配置

#开启熔断机制
feign.hystrix.enabled=true

# 设置hystrix超时时间,默认1000ms
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=6000

3、创建熔断器的实现类

这里我是做一个需要调用其他模块内删除阿里云已经上传的视频方法

@Component										  
public class VodFileDegradeFeignClient implements VodClient {//VodClient调用其他模块方法的接口
    @Override
    public R removeVideo(String videoId) {
        return R.error().message("time out");
    }

    @Override
    public R removeVideoList(List videoIdList) {
        return R.error().message("time out");
    }
}

4、修改VodClient接口的注解

		 //(需要调用模块在nacos内注册的名称)
@FeignClient(name = "service-vod", fallback = VodFileDegradeFeignClient.class)
@Component
public interface VodClient {
    @DeleteMapping(value = "/eduvod/vod/{videoId}")
    public R removeVideo(@PathVariable("videoId") String videoId);

    @DeleteMapping(value = "/eduvod/vod/delete-batch")
    public R removeVideoList(@RequestParam("videoIdList") List videoIdList);
}

简单四部搞定

### Hystrix 使用指南和最佳实践 Hystrix 是 Netflix 开源的一款用于处理分布式系统的延迟和容错的库,主要应用于微服务架构中的断路器模式实现。以下是有关 Hystrix 的使用方法、配置以及一些最佳实践。 #### 基本概念 Hystrix 提供了一种机制,在远程调用失败或者超时时保护并控制依赖的服务交互。它通过隔离点之间的访问来防止级联故障,并提供回退选项以增强系统的弹性[^1]。 #### 配置与使用 为了集成 Hystrix 到项目中,通常需要引入相应的 Maven 或 Gradle 依赖项。下面是一个简单Spring Cloud 中使用的例子: ```xml <dependency> <groupId>com.netflix.hystrix</groupId> <artifactId>hystrix-core</artifactId> <version>1.5.18</version> </dependency> ``` 接着可以通过 `@EnableCircuitBreaker` 注解启用断路器功能,并在具体的方法上标注 `@HystrixCommand` 来定义命令行为及其回退逻辑。 ```java import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand; import org.springframework.stereotype.Service; @Service public class MyService { @HystrixCommand(fallbackMethod = "fallback") public String callExternalService() { // 调用外部服务的代码 return externalCall(); } private String fallback() { return "Fallback response"; } } ``` 上述代码展示了如何设置一个带有默认回退方法的基础 Hystrix 命令。如果主业务逻辑执行过程中出现问题,则会触发指定的回退函数。 #### 性能优化与监控 除了基础的功能外,还需要关注性能调整方面的工作。比如可以自定义线程池大小、请求超时时间等参数;同时利用 Turbine 收集多个实例上的指标数据进行集中化展示以便于实时监测整个集群的状态变化情况[^4]。 另外值得注意的是随着技术栈的发展趋势,Hystrix 已经逐渐被 Resilience4j 所取代,后者更加轻量级且易于维护,特别是在响应式编程场景下表现尤为突出[^2]. #### 最佳实践总结 - **合理划分模块**: 将不同类型的请求分配到独立的资源组里运行,这样即使某个部分出了差错也不会影响其他正常工作的组件. - **设定恰当阈值**: 根据实际情况调整熔断条件(如错误百分比),既不过早也不过晚地激活防护措施. - **定期测试恢复能力**: 不仅要验证常规操作流程下的正确性还要模拟各种异常状况下来评估整体健壮程度. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

born_stubborn

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

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

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

打赏作者

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

抵扣说明:

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

余额充值