开发者社区 > 云原生 > 正文

如果资源是递归调用的,那么线程数和QPS将被加倍计数?

我认为单个线程应该只评估一次

@Test public void flow(){ initFlowQpsRule(); Entry entry = null; // 务必保证finally会被执行 try { // 资源名可使用任意有业务语义的字符串 entry = SphU.entry("zuoqi"); // 被保护的业务逻辑 // do something... System.out.println(entry.getCurNode().curThreadNum()); int i = atomicInteger.incrementAndGet(); if(i == 10){ return; } flow(); } catch (BlockException e1) { // 资源访问阻止,被限流或被降级 // 进行相应的处理操作 } finally { if (entry != null) { entry.exit(); } } }

jdk1.8 sentinel 1.7.0

原提问者GitHub用户zuoqi1993125

展开
收起
云上静思 2023-05-19 16:37:53 88 0
1 条回答
写回答
取消 提交回答
  • 每次调用 SphU.entry(xxx) 都会进行统计,而与当前调用链路无关;若希望只统计一次,可以把 SphU.entry(xxx) 包在循环调用或递归调用前面

    try (Entry e = SphU.entry("xxx")) { // do your recursive invocation } catch (BlockException e) { // handle the block exception here }

    原回答者GitHub用户sczyh30

    2023-05-19 22:43:25
    赞同 展开评论 打赏
问答分类:
问答地址:

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关电子书

更多
多IO线程优化版 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载