spring cloud Hystrix服务容错--触发降级和设置超时时间

本文深入探讨Hystrix服务容错机制,包括服务降级、依赖隔离和服务熔断等关键概念。通过实例演示如何在Spring Cloud项目中集成Hystrix,实现对外部服务调用的容错处理,提高系统稳定性和可用性。

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

1.为服务提供一系列的服务容错保护机制
2.Hystrix服务容错作用:
1.服务降级
2.依赖隔离
3.服务熔断
3.服务降级
在这里插入图片描述
4.加入依赖

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

5.主类加入注解
在这里插入图片描述
6.测试服务降低

/**
     * 方式三
     * 测试Hystrix 服务降低
     *调用别的服务过程中出现异常 则调用fallback方法
     */

    @Autowired
    private RestTemplate restTemplate;
    @HystrixCommand(fallbackMethod = "fallback")
    @GetMapping("/getProductMsg3")
    public String getMsg3()
    {
        String response= restTemplate.getForObject("http://PRODUCT/msg",String.class);
        log.info("response:"+response );
        return response;

    }

    /**
     * 调用别的服务过程中出现异常 则调用此方法
     * @return
     */
    private String fallback()
    {
        return "太拥挤了 请稍后再试";
    }

7.效果:
在order服务调用product服务时 product出现异常或者挂掉则触发降低

在这里插入图片描述
8.默认Fallback 和设置超时时间 默认是一秒 在HystrixCommandProperties类中找超时的配置 如果请求超过一秒则不管是否异常就触发降级 所有此时就需要把超时设置得长一些
在这里插入图片描述

 /**
     * 方式三
     * 测试Hystrix 服务降低
     *调用别的服务过程中出现异常 则调用fallback方法
     */
    /*HystrixCommandProperties*/
    @Autowired
    private RestTemplate restTemplate;
    @HystrixCommand(commandProperties = {@HystrixProperty(name ="execution.isolation.thread.timeoutInMilliseconds" ,value ="3000" )})
    @GetMapping("/getProductMsg3")
    public String getMsg3()
    {
        String response= restTemplate.getForObject("http://PRODUCT/msg",String.class);
        log.info("response:"+response );
        return response;

    }

    /**
     * 调用别的服务过程中出现异常 则调用此方法
     * @return
     */
    private String fallback()
    {
        return "太拥挤了 请稍后再试";
    }

    /**
     * 当@HystrixCommand(fallbackMethod = "fallback")
     * 不指定fallback时调用次方法
     * @return
     */
    private String defaultFallback()
    {
        return "默认提示:太拥挤了 请稍后再试";
    }
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值