版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
应⽤7#coding:utf8importtimeclass init(self,capacity,leaking_rate):self.capacity=capacity#漏⽃容量self.leaking_rateleaking_rate漏嘴流
self.left_quotacapacityself.leaking_tstime.time()defmake_space(self):now_ts=time.time()delta_tsnow_tsself.leaking_tsdelta_quota=delta_ts*self.leaking_rate#⼜可以腾出不少空间了ifdelta_quota1:self.left_quotadelta_quotaself.leaking_tsnow_tsifself.left_quotaself.capacity:self.left_quota=defwatering(self,quota):ifself.left_quotaquota:self.left_quota-=quotareturnTruereturnfunnelscapacityleaking_rate漏嘴流⽔速率quota/sdefis_action_allowed(user_id,action_key,capacity,key='%s:%s'%(user_id,action_key)funnel=funnels.get(key)ifnotfunnel=Funnel(capacity,leaking_rate)funnels[key]=funnelreturnforiinprintis_action_allowed('laoqian','reply',15,0.5)JavapublicpublicclassFunnelRateLimiterstaticclass{intcapacity;floatleakingRate;intleftQuota;longleakingTs;publicFunnel(intcapacity,floatleakingRate){this.capacity=capacity;this.leakingRate=leakingRate;this.leftQuota=capacity;this.leakingTs=}voidmakeSpace()longnowTs=System.currentTimeMillis();longdeltaTs=nowTs-leakingTs;intdeltaQuota=(int)(deltaTs*if(deltaQuota0this.leftQuota=capacity;this.leakingTs=nowTs;}if(deltaQuota1是}this.leftQuota+=deltaQuota;this.leakingTs=nowTs;if(this.leftQuota>this.capacity)this.leftQuota=}}booleanwatering(int{if(this.leftQuota>={this.leftQuota-=quota;returntrue;}return}}privateMap<String,Funnel>funnels=newpublicbooleanisActionAllowed(StringuserId,StringactionKey,intcapacity,floatleakingRate){Stringkey=String.format("%s:%s",userId,Funnelfunnel=funnels.get(key);if(funnel==null){funnel=newFunnel(capacity,leakingRate);funnels.put(key,funnel);}returnfunnel.watering(1需要1个}}Funnel对象的make_space决于过去了多久以及流⽔的速率。Funnel对象占据的空间⼤⼩不再Redis的基我们观察Funnel对象的⼏个字段,我们发现可以将Funnel对象的内容按字段存储到⼀个hash结构中,灌⽔的时候将hash结构的字段取出来进⾏逻辑运算后,再将新值回填到hash结构中就完成了⼀但是有个问题,我们⽆法保证整个过程的原⼦性。从hash结构中取值,然后在内存⾥运算,再回填到hash结构,这三个过程⽆法原⼦们该如何解决这个问题呢?Redis-Cell救星来了!Redis-Redis4.0提供了⼀个限流Redis模块,它叫redis-cell。该模块也>cl.throttle1▲▲▲▲▲||||└─────1quota可选参数,默认值也是 |└──┴───────30operations/60seconds这是漏⽔速率 └─────────────capacity上⾯这个指令的意思是允许「⽤户⽼钱回复⾏为」的频率为每60s最多30次(漏⽔速率),漏⽃的初始容量为15,也就是说⼀开始可以连续回复15个帖⼦,然后才开始受漏⽔速率的影响。我们看到这个指令中漏⽔速率变成了2个参数,替代了之前的单个浮点数。⽤>>cl.throttlelaoqian:reply1530(integer)(integer)(integer)4)(integer)-0表示允许,1漏⽃容量漏⽃剩余空间5(integer 组的第四个值进⾏sleep即可,如果不想阻塞线程,也可以异步定漏⽃限流模块除了应⽤于UGC1.《Redis-Cell作者ItamarHaberRedis-Cell作者ItamarHa
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 浙江国企招聘2025绍兴市国资委绍兴市退役军人事务局联合组织开展“戎耀新程智汇国资”绍兴市国有企业招聘87人笔试历年难易错考点试卷带答案解析
- 四川宏达(集团)有限公司本部及所属企业2025年12月社会招聘笔试历年难易错考点试卷带答案解析
- 广东省肇庆市高中英语 Unit 3 The Million Pound Bank NoteExplain the paper of the exercises at night(the second week)教学设计 新人教版必修3
- 2026南斗六星技术有限公司校园招聘笔试历年常考点试题专练附带答案详解
- 给水管道检测与维护方案
- 2025江西萍乡市人才发展集团有限公司第二批次招聘3人订笔试历年难易错考点试卷带答案解析
- 2025广东江门市城建集团有限公司公路运营分公司招聘1人笔试历年难易错考点试卷带答案解析
- 不限教学设计中职专业课-MySQL数据库-计算机类-电子与信息大类
- 2025四川宜宾钲兴智造科技有限公司第一批项目制员工招聘4人笔试历年常考点试题专练附带答案详解
- 2025云南盛佳新材料有限责任公司招聘9人笔试历年常考点试题专练附带答案详解
- 第五章-空中交通管理-空域教学课件
- 第五章-喀斯特地貌课件
- 渠道混凝土衬砌专项施工技术方案
- 英语学术论文写作智慧树知到答案章节测试2023年西安外国语大学
- 朗诵朗读技巧大全ppt
- 新版《西北电力系统调度规程》持证上岗培训资料
- 聚合物材料测试方法课件
- ERP系统-E10-50培训教材-总账课件
- 《骆驼祥子》 完整版课件
- 唐代佛教植物装饰纹样的艺术特色
- 家乡的艺术---芜湖铁画 PPT
评论
0/150
提交评论