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

image-20220224142201168

POM引入依赖

 <dependency>
   <groupId>io.github.resilience4j</groupId>
   <artifactId>resilience4j-bulkhead</artifactId>
   <version>1.7.0</version>
</dependency>

信号量隔离修改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

image-20220211181338963

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

CuteTTU

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

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

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

打赏作者

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

抵扣说明:

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

余额充值