服务接口API限流

1.实际场景中常用的限流策略:

1)nginx前端限流  
    按照一定的规则如账号、ip、系统调用逻辑等在Nginx层面做限流。
2)业务应用系统限流  
    1.客户端限流  
    2.服务端限流
3)数据库限流
    红线区、力保数据库  

2.常用的限流算法

1)漏桶算法  
    思路是强行限制传输速率,水(请求)入桶,桶中的水以一定速度出水,桶满则禁止访问;

2)令牌桶算法  
    思路是传输速率可以调节,令牌按照规定速度放到桶里,如果桶满则暂停放令牌,用户每次请求从桶里拿走一个令牌,如果没有令牌了,就停止访问。  

3)基于redis功能的实现
    通过用户访问的唯一标识字段生成一个为期60秒的键,这个用户每访问一次,将键值加1,在60秒内当键值增加到10的时候,就禁止访问服务接口。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一、场景描述很多做服务接口的人或多或少的遇到这样的场景,由于业务应用系统的负载能力有限,为了防止非预期的请求对系统...
    dreamer_lk阅读 7,186评论 0 9
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,752评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,224评论 19 139
  • 最近喜欢思维锻炼。比如数学。 我一直想找到事物的本原,潜伏虚微之深,但难以触摸那永恒的光亮。 数形结合,转化思想。...
    荡云雪阅读 1,144评论 0 0
  • 本文利用Docker实现mysql主从同步/读写分离,当然你也可以开两台虚拟机来搭建,方法都一样。只是用Docke...
    茶艺瑶阅读 4,692评论 2 0

友情链接更多精彩内容