httpdns中限流的方案

来源:互联网 发布:淘宝上的洋酒可以买吗 编辑:程序博客网 时间:2024/06/02 12:01

采用令牌桶算法的思想:

github地址:https://github.com/juju/ratelimit

1、在Compass结构体中增加一个成员bucket,定义一个专门的初始化函数用于bucket的初始化

2、在server_route_d函数的第一行,调用bucket.TakeAvailable(1)函数

3、或者在解析完hosts个数为n后,调用bucket.TakeAvailable(n)函数

4、针对TakeAvailable函数的返回结果,最简单的方式为直接Fill_Json后return,这样直接放弃处理了

5、稍微复杂点的方式:

(1)设置三次循环调用TakeAvailable调用,如果调用成功,则执行

(2)如果三次循环调用后仍不成功,则再进行三次另外的循环:

        -1-:先调用wait,然后再TakeAvailable,若仍然不成功

        -2-:若三次这样的调用后仍然不成功,则再放弃处理,跳到Fill_Json处理后return


0 0
原创粉丝点击