httpdns中限流的方案

    xiaoxiao2021-03-25  146

    采用令牌桶算法的思想:

    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

    转载请注明原文地址: https://ju.6miu.com/read-9760.html

    最新回复(0)