分布式限流总结

1、计数器

java内部可以使用原子计数器AtomicInteger\Semaphore信号量来做简单的限流

// 限流的个数
    private int maxCount = 10;
    // 指定的时间内
    private long interval = 60;
    // 原子类计数器
    private AtomicInteger atomicInteger = new AtomicInteger(0);
    // 起始时间
    private long startTime = System.currentTimeMillis();

    public boolean limit(int maxCount, int interval) {
        atomicInteger.addAndGet(1);
        if (atomicInteger.get() == 1) {
            startTime = System.currentTimeMillis();
            atomicInteger.addAndGet(1);
            return true;
        }
        // 超过了间隔时间,直接重新开始计数
        if (System.currentTimeMillis() - startTime > interval * 1000) {
            startTime = System.currentTimeMillis();
            atomicInteger.set(1);
            return true;
        }
        // 还在间隔时间内,check有没有超过限流的个数
        if (atomicInteger.get() > maxCount) {
            return false;
        }
        return true;
    }

2、漏桶算法

漏桶算法思路比较简单,我们把水比作是请求,漏桶比作是系统处理能力极限,水先进入到漏桶里,漏桶会按照一定速率流出,当流出的速率小于流入的速率时,由于漏桶容量有限,后续进入的水直接溢出。

3、令牌桶算法

系统会维护一个令牌桶,以一个恒定的速度往桶里放入令牌(token),这时如果有请求进来想要被处理,则需要先从桶里获取一个令牌,当桶里没有令牌可取时,则该请求被拒绝服务。令牌桶算法通过控制桶容量、发放令牌速率,来达到对请求的限制。

4、redis+lua

5、网关层

相关推荐

  1. 【微服务】分布式如何实现

    2024-05-25 19:46:37       65 阅读
  2. Springboot Redis Lua 分布式

    2024-05-25 19:46:37       71 阅读
  3. 分布式系统接口方案

    2024-05-25 19:46:37       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-25 19:46:37       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-25 19:46:37       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-25 19:46:37       82 阅读
  4. Python语言-面向对象

    2024-05-25 19:46:37       91 阅读

热门阅读

  1. HTTP与HTTPS的前尘往事

    2024-05-25 19:46:37       32 阅读
  2. C# WPF入门学习(一)

    2024-05-25 19:46:37       25 阅读
  3. 2024年3月小程序类目调整汇总公告

    2024-05-25 19:46:37       32 阅读
  4. 机柜里面的设备有哪些

    2024-05-25 19:46:37       32 阅读
  5. Go语言标准库之log和三方库zap

    2024-05-25 19:46:37       25 阅读
  6. zookeeper选主之LeaderLatch

    2024-05-25 19:46:37       25 阅读
  7. [前端|vue] v-if 和v-show的区别,为什么功能会类似

    2024-05-25 19:46:37       30 阅读
  8. 学校上课,是耽误我学习了。。

    2024-05-25 19:46:37       29 阅读
  9. Python解析网页

    2024-05-25 19:46:37       40 阅读
  10. 【Kubernetes】Pod无法访问Service域名问题排查

    2024-05-25 19:46:37       28 阅读