最赞回答 / itbsl
代码层面做限流的话,可以用redis来配合做,假设你的一个接口的请求限制的一个IP1s内只能有一个请求,则可以将接口名+IP作为键存一个bool值true,并且设置生命周期为1s,每次处理请求时先从redis里根据“接口名+IP”拿值,如果该值为true,说明一秒内已经有过一次请求,这种就可以直接拒绝不继续往下处理,相反如果拿不到值了,说明之前没有请求过或者请求的时间已经是1s之前了,这种就允许通过,继续处理下面的业务。
2019-11-29
讲师回答 / 皮奇
这个其实是个高空用的问题,属于运维层面要解决的事情,一般redis不是直连,而是通过vip连接到proxy,proxy再根究切片配置转发到redis实例,每个redis实例是一主多从,读写都在主,主挂了之后会自动通过raft算法选举出一个新的主,用于确保服务的高可用。市面上有比较成熟的解决方案,如codis,可以了解下。
2019-10-26
讲师回答 / 皮奇
同学你好,你的思路不错,可以继续去想下直接incrby改会有什么问题,老师提供的思路只是其中一个方案,真正场景实现肯定会有非常多的方案,需要大家自己思考。redis->eval本身就是执行lua脚本,redis->incrby理论上也可以防止边界条件的发生,不会造成超卖,因为incrby就实现了查询+修改的原子操作,但是有一点点小缺点就是,不能做到只要一超卖了就直接终止+1。
2019-10-01
讲师回答 / 皮奇
同学你好,具体哪听不懂可以反馈给我,我后续慢慢优化。lua一门脚本语言,是一门短小精悍的语言,代码量非常少,可以嵌入到任何一门C开发的工具中,因此在nginx、redis中都有应用,可以快速的扩展nginx与redis这两个工具的功能。
2019-09-04