如何使用Apollo配置PARAMS来配置热点参数限流?现在规则包括资源、计数、等级、持续时间InSec、控制行为和
可以配置最大排队时间、paramIdx、paramFlowItemList、clusterMode、clusterConfig,但如何配置热门参数?
热点参数的电流限制是否需要与硬编码(SphU.entry方法)相结合?你能只使用Apollo来配置它吗?
1、Apollo configure: { "resource": "paramFlowUid", "count": 50, "grade": 1, "controlBehavior": 0, "paramIdx": 0 }
2、code : /** 热点参数限流--热点参数为uid */ @ApiOperation(value = "热点参数限流api", notes = "热点参数限流api") @SentinelResource(value = "paramFlowUid") @SuppressWarnings("all") @PostMapping("freqParamFlowUid.do") public @responsebody String freqParamFlowUid(@RequestParam("uid") Long uid,@RequestParam("goodsId") Long goodsId) { Entry entry = null; String retVal; try{ // 只对参数uid进行限流,参数goodsId不进行限制 entry = SphU.entry("paramFlowUid", EntryType.IN, 1, uid); retVal = "passed"; }catch(BlockException e){ retVal = "blocked"; }finally { if(entry!=null){ entry.exit(); } } return retVal + "=====uid: " + uid + ", goodsId: " + goodsId; }
3、result
环境:springcloud、Apollo
原提问者GitHub用户liran0705
热点参数传入参数的方式参考:https://github.com/alibaba/Sentinel/wiki/热点参数限流#基本使用 规则配置可通过动态规则源、控制台或 ParamFlowRuleManager 的形式手动加载。
原回答者GitHub用户sczyh30
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。