Springboot中hystrix的基本使用

SpringCloud中使用hystrix来做熔断
导入依赖

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

application.yml文件中配置启动熔断器

feign:
  hystrix:
    enabled: true

在启动类上使用纾解标注启动hystrix

@SpringBootApplication
@EnableEurekaClient
@MapperScan(basePackages = {"com.neuedu.shop.mapper"}) //mybatis自动扫包位置
@EnableFeignClients
@EnableCircuitBreaker
public class OrderServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(OrderServiceApplication.class,args);
    }
}

写一个类,这个类是给熔断器调用的,要求方法名与feign 中的方法名一致。要添加@Component注解

@Component
public class OrderHystrixClient implements OrderFeignClient{

    @Override
    public ProductInfo getProductById(Integer id) {
        System.out.println("熔断器执行");
        //会用redis的话,可以抓取缓存
        return ProductInfo.invalid();
    }

    @Override
    public Integer updateProduct(ProductInfo productInfo) {
        return -1;
    }
}

在feign接口的注解中使用属性标注替代类,记住加上fallback = OrderHystrixClient.class,如果调用服务失败则采用熔断机制

@FeignClient(value = "product-service",fallback = OrderHystrixClient.class)
public interface OrderFeignClient {

    //以抽象方法的形式表示调用
    //feign底层会自动转化对象类型
    //使用requestMapping注解来表示你要调用那个请求
    @RequestMapping(value = "/shop-product/insideGetProductById",method = RequestMethod.GET)
    ProductInfo getProductById(@RequestParam("id") Integer id);

    @RequestMapping(value = "/shop-product/insideUpdateProduct",method = RequestMethod.POST)
    Integer updateProduct(@RequestBody ProductInfo productInfo);

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值