zoukankan      html  css  js  c++  java
  • 服务熔断


    @HystrixProperty(name = "circuitBreaker.enabled", value = "true"),//设置熔断
    @HystrixProperty(name = "circuitBreaker.requestVolumeThreshold", value = "10"), //最小请求数
    @HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds", value = "10000"), //10秒
    @HystrixProperty(name = "circuitBreaker.errorThresholdPercentage", value = "60") //滚动时间10秒钟,有7次发生错误。断路器被设置为打开状态。

    一、HystrixController .java

    @RestController
    @DefaultProperties(defaultFallback = "defaultFallback")
    public class HystrixController {
    
    
    
        //@HystrixCommand(fallbackMethod = "fallback")
        //2、超时设置
        /*@HystrixCommand(commandProperties = {
                @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000") //超时时间设置为3秒
        })*/
        //3.
        @HystrixCommand(commandProperties = {
                @HystrixProperty(name = "circuitBreaker.enabled", value = "true"),//设置熔断
                @HystrixProperty(name = "circuitBreaker.requestVolumeThreshold", value = "10"),
                @HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds", value = "10000"),
                @HystrixProperty(name = "circuitBreaker.errorThresholdPercentage", value = "60")
        })
        @GetMapping("/getProductInfoList")
        public  String getProductInfoList(@RequestParam("number") Integer number){
            if(number % 2 == 0){
                return  "success";
            }
            RestTemplate restTemplate = new RestTemplate();
           return restTemplate.postForObject("http://127.0.0.1:8091/product/listForOrder", Arrays.asList("157875196366160022"),String.class);
    
        }
    
        private String fallback(){
            return "太拥挤了,请稍后再试~~";
        }
    
    
        private String defaultFallback(){
            return "默认提示:太拥挤了,请稍后再试~~";
        }
    }
    

      

    Product工程中的方法

        @PostMapping("/listForOrder")
        public List<ProductInfo> listForOrder(@RequestBody List<String> productIdList){
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return  productService.findList(productIdList);
        }
    

      

    调用:

    number为2时成功返回

    number为1时,触发熔断

    熔断:

    不停的调用 http://localhost:8081/getProductInfoList?number=1 。

    然后调用http://localhost:8081/getProductInfoList?number=2, 也出现拥挤提示

    然后再次调用http://localhost:8081/getProductInfoList?number=2 就正常了。

    二、使用配置,设置过期时间

    设置超时时间为1秒

    spring:
      application:
          name: order
      redis:
        host: 47.48.47.40
        port: 6379
      cloud:
        config:
          discovery:
            enabled: true
            service-id: CONFIG
          profile: test
    hystrix:
      command:
        default:
          execution:
            isolation:
               thread:
                  timeoutInMilliseconds: 1000
    

      

    接口配置

        @HystrixCommand
        @GetMapping("/getProductInfoList")
        public  String getProductInfoList(@RequestParam("number") Integer number){
            if(number % 2 == 0){
                return  "success";
            }
            RestTemplate restTemplate = new RestTemplate();
           return restTemplate.postForObject("http://127.0.0.1:8091/product/listForOrder", Arrays.asList("157875196366160022"),String.class);
    
        }
    

      

    三、为单个方法配置超时时间

    给getProductInfoList设置超时时间为3秒

  • 相关阅读:
    解决 Android SDK Manager不能下载旧版本的sdk的问题
    [置顶] 如何合并文件中的内容?
    JSTL解析——005——core标签库04
    C中的几组指针
    别动我的奶酪:CSV文件数据丢零现象及对策
    重载(overload),覆盖/重写(override),隐藏(hide)
    IOS 轻量级数据持久化 DataLite
    记录路径dp-4713-Permutation
    android 多媒体数据库详解
    Data Recovery Advisor(数据恢复顾问)
  • 原文地址:https://www.cnblogs.com/linlf03/p/10398466.html
Copyright © 2011-2022 走看看