服务断路器_Resilience4j信号量隔离实现

服务断路器_Resilience4j信号量隔离实现_第1张图片

POM引入依赖

 
   io.github.resilience4j
   resilience4j-bulkhead
   1.7.0

信号量隔离修改YML文件

resilience4j:
 #信号量隔离
  bulkhead:
   instances:
    backendA:
    # 隔离允许并发线程执行的最大数量
     maxConcurrentCalls: 5
    # 当达到并发调用数量时,新的线程的阻塞时间
     maxWaitDuration: 20ms


编写controller

/**
   * 测试信号量隔离
   * @return
   */
  @Bulkhead(name = "backendA",type = Bulkhead.Type.SEMAPHORE)
  @GetMapping("bulkhead")
  public String bulkhead() throws InterruptedException {
    log.info("************** 进入方法 *******");
    TimeUnit.SECONDS.sleep(10);
    String index = paymentOpenFeignService.index();
    log.info("************** 离开方法 *******");
    return index;
   }

测试

配置隔离并发线程最大数量为5

服务断路器_Resilience4j信号量隔离实现_第2张图片

你可能感兴趣的:(java)