SpringCloud学习之hystrix断路器(请求熔断和服务降级)

一、添加pom文件

<!-- 断路器-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>

二、启动类添加注解(@EnableHystrix)

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
@EnableHystrix
public class OrderApp {

    public static void main(String[] args) {
        SpringApplication.run(OrderApp.class,args);
    }

    @Bean
    @LoadBalanced
    RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

三、yml文件配置

开启断路器

#开启断路器
feign:
  hystrix:
    enabled: true

四、使用Feign方式添加断路器

4.1 添加MyFallBack类,实现FeignService接口;实现方法中返回降级处理内容

@Component
public class MyFallBack implements FeignService {

    public String getUser(int id) {
        return "getUser error";
    }
}

4.2 FeignService接口上添加(fallback = MyFallBack.class)

@FeignClient(value = "dc-user",fallback = MyFallBack.class)
public interface FeignService {

    @RequestMapping(value = "/user/{id}",method = RequestMethod.GET)
    String getUser(@PathVariable("id") int id);
}

五、使用RestTemplate方式添加断路器

5.1 在OrderService中添加降级处理方法getUser;添加  @HystrixCommand(fallbackMethod = "getUser");fallbackMethod为降级处理方法,getUser为最下面的一个降价处理方法。

@Service
public class OrderSercice {

    @Autowired
    private RestTemplate restTemplate;

    @HystrixCommand(fallbackMethod = "getUser")
    public String getUSer(int id){
        String url = "http://dc-user/user/{id}";
        String result = restTemplate.getForObject(url,String.class,id);
        return result;
    }

    //服务降级处理方法
    public String getUser(int id){
        return "getUser error2";
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

JAVA菜鸟程序员

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

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

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

打赏作者

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

抵扣说明:

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

余额充值