你了解哪些Java限流算法?
大家好,我是锋哥。今天分享关于【你了解哪些Java限流算法?】面试题。希望对大家有帮助;
你了解哪些Java限流算法?
1000道 互联网大厂Java工程师 精选面试题-Java资源分享网
Java 中常用的限流算法主要有以下几种,它们广泛应用于处理流量控制、API请求限制等场景:
1. 令牌桶算法(Token Bucket)
令牌桶算法是限流中最常用的一种方法。其基本思想是:
- 系统按固定速率向桶中放入令牌,每次请求需要消耗一个令牌。
- 如果桶中没有足够的令牌,请求会被拒绝或者被延迟处理。
- 如果令牌桶的容量大于实际请求速率,系统允许突发流量(超过速率的流量)。
特点:
- 支持突发流量。
- 限制速率比较平滑,可以动态调整。
实现方式:
- 使用一个线程定时向桶中放入令牌。
- 请求到达时,检查令牌桶是否有令牌。
public class TokenBucket {private final long capacity;private final long refillInterval;private long availableTokens;private long lastRefillTime;public TokenBucket(long capacity, long refillInterval) {this.capacity = capacity;this.refillInterval = refillInterval;this.availableTokens = capacity;this.lastRefillTime = System.currentTimeMillis();}public synchronized boolean acquire() {long now = System.currentTimeMillis();long elapsedTime = now - lastRefillTime;long tokensToAdd = elapsedTime / refillInterval;availableTokens = Math.min(capacity, availableTokens + tokensToAdd);lastRefillTime = now;if (availableTokens > 0) {availableTokens--;return true;}return false;}
}
2. 漏斗算法(Leaky Bucket)
漏斗算法通过一个固定容量的桶来控制请求速率。桶中有一定的容量,固定的速率会“漏掉”桶中的水,水(请求)按一定速率流出。
特点:
- 控制流量的输出速率平稳。
- 不允许突发流量,所有流量都按固定速率流出。
实现方式:
- 每次请求到来时,检查桶中的水量(请求数),如果桶已经满了,就拒绝请求。
- 否则允许请求进入桶,按固定速率流出。
public class LeakyBucket {private final long capacity;private final long leakRate;private long waterLevel;private long lastLeakTime;public LeakyBucket(long capacity, long leakRate) {this.capacity = capacity;this.leakRate = leakRate;this.waterLevel = 0;this.lastLeakTime = System.currentTimeMillis();}public synchronized boolean acquire() {long now = System.currentTimeMillis();long elapsedTime = now - lastLeakTime;long leakedWater = elapsedTime / leakRate;waterLevel = Math.max(0, waterLevel - leakedWater);lastLeakTime = now;if (waterLevel < capacity) {waterLevel++;return true;}return false;}
}
3. 计数窗口算法(Fixed Window Counter)
计数窗口算法是最简单的一种限流算法,它将时间划分为多个固定的时间窗口,每个时间窗口内可以接受一定数量的请求。
特点:
- 简单易理解。
- 容易受到“窗口切分”的影响,可能会在窗口的边界出现突发流量。
实现方式:
- 每个窗口内计数器限制请求次数。
- 请求到来时,检查当前时间窗口是否超过了限制。
public class FixedWindowCounter {private final int limit;private int count;private long lastWindowStartTime;public FixedWindowCounter(int limit) {this.limit = limit;this.count = 0;this.lastWindowStartTime = System.currentTimeMillis();}public synchronized boolean acquire() {long currentTime = System.currentTimeMillis();if (currentTime - lastWindowStartTime >= 1000) { // New windowcount = 0;lastWindowStartTime = currentTime;}if (count < limit) {count++;return true;}return false;}
}
4. 滑动窗口算法(Sliding Window Log)
滑动窗口算法是对固定窗口的改进,避免了固定窗口中产生的突发流量问题。它通过记录每个请求的时间戳,然后根据时间戳来判断请求是否超出了时间窗口。
特点:
- 较为精确地控制请求数量,避免了固定窗口的突发流量问题。
- 实现相对复杂。
实现方式:
- 使用队列记录每个请求的时间戳,当新请求到来时,去除过期的时间戳并检查当前窗口内的请求数量。
import java.util.LinkedList;public class SlidingWindowLog {private final int limit;private final long windowSize;private LinkedList<Long> requests;public SlidingWindowLog(int limit, long windowSize) {this.limit = limit;this.windowSize = windowSize;this.requests = new LinkedList<>();}public synchronized boolean acquire() {long currentTime = System.currentTimeMillis();while (!requests.isEmpty() && currentTime - requests.peekFirst() >= windowSize) {requests.pollFirst();}if (requests.size() < limit) {requests.addLast(currentTime);return true;}return false;}
}
5. Redis限流
使用 Redis 进行限流是分布式环境中常见的一种做法,主要使用 Redis 的 INCR 和 EXPIRE 命令来实现。
特点:
- 适用于分布式系统。
- 可扩展性强。
实现方式:
- 使用 Redis 存储请求计数,设置过期时间。
- 请求时进行计数和判断。
public class RedisRateLimiter {private final String redisKey;private final int limit;private final long period;private final Jedis jedis;public RedisRateLimiter(String redisKey, int limit, long period, Jedis jedis) {this.redisKey = redisKey;this.limit = limit;this.period = period;this.jedis = jedis;}public boolean acquire() {long currentTime = System.currentTimeMillis() / 1000;String key = redisKey + ":" + currentTime;Long count = jedis.incr(key);if (count == 1) {jedis.expire(key, (int) period);}return count <= limit;}
}
6. 漏桶 + 令牌桶混合
某些场景中,结合漏桶算法和令牌桶算法可以平衡处理流量控制。
特点:
- 结合两种算法的优点,既支持突发流量,又能够平稳流量。
这些限流算法各有优缺点,适用于不同的场景。令牌桶算法通常用于需要支持突发流量的场景,漏桶算法适用于对流量的平滑控制,而计数窗口和滑动窗口算法适合于较为简单的应用场景。对于分布式应用,使用 Redis 等中间件进行限流会更有效。
相关文章:
你了解哪些Java限流算法?
大家好,我是锋哥。今天分享关于【你了解哪些Java限流算法?】面试题。希望对大家有帮助; 你了解哪些Java限流算法? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Java 中常用的限流算法主要有以下几种,它们广泛应用于处理流量控…...
【漫话机器学习系列】065.梯度(Gradient)
梯度(Gradient) 在数学和机器学习中,梯度是一个向量,用来表示函数在某一点的变化方向和变化率。它是多变量函数的一阶偏导数的组合。 梯度的定义 设有一个标量函数 ,它对 是可微的,则该函数在某一点的…...
BswM(基础软件管理)详解
BswM(基础软件管理)详解 BswM(Basic Software Manager) 是 AUTOSAR BSW 的核心模块之一,负责协调基础软件(BSW)各模块的行为,根据系统状态、规则或事件动态配置其他模块。其设计目标…...
上位机知识篇---GitGitHub
文章目录 前言Git&GitHub是什么?GitGitHub Git和GitHub的区别定位功能使用方式开源协作 Git常用命令操作1. 配置2. 仓库操作3. 文件操作4. 分支与合并5.远程操作6.撤销更改7.查看历史 GitHub常用操作1.创建仓库2.Fork仓库3.Pull Request4.Issue跟踪5.代码审查 G…...
网站快速收录:提高页面加载速度的重要性
本文转自:百万收录网 原文链接:https://www.baiwanshoulu.com/32.html 网站快速收录中,提高页面加载速度具有极其重要的意义。以下从多个方面详细阐述其重要性: 一、提升用户体验 减少用户等待时间:页面加载速度直接…...
Vue.js组件开发-实现全屏背景图片滑动切换特效
使用 Vue 实现全屏背景图片滑动切换特效的详细步骤、代码、注释和使用说明。 步骤 创建 Vue 项目:使用 Vue CLI 创建一个新的 Vue 项目。准备图片资源:准备好要用于背景切换的图片,并将它们放在项目的合适目录下。编写 HTML 结构࿱…...
DeepSeek r1本地安装全指南
环境基本要求 硬件配置 需要本地跑模型,兼顾质量、性能、速度以及满足日常开发需要,我们需要准备以下硬件: CPU:I9内存:128GB硬盘:3-4TB 最新SSD,C盘确保有400GB,其它都可划成D盘…...
LitGPT - 20多个高性能LLM,具有预训练、微调和大规模部署的recipes
文章目录 一、关于 LitGPT二、快速启动安装LitGPT高级安装选项 从20多个LLM中进行选择 三、工作流程1、所有工作流程2、微调LLM3、部署LLM4、评估LLM5、测试LLM6、预训练LLM7、继续预训练LLM 四、最先进的功能五、训练方法示例 六、项目亮点教程 一、关于 LitGPT LitGPT 用于 …...
deepseek R1 14b显存占用
RTX2080ti 11G显卡,模型7b速度挺快,试试14B也不错。 7B显存使用5.6G,14B显存刚好够,出文字速度差不多。 打算自己写个移动宽带的IPTV播放器,不知道怎么下手,就先问他了。...
无用知识研究:对std::common_type以及问号表达式类型的理解
先说结论: 如果问号表达式能编译通过,那么std::common_type就能通过。因为common_type的底层依赖的就是?: common_type的实现里,利用了问号表达式:ternary conditional operator (?:) https://stackoverflow.com/questions/14…...
MapReduce概述
目录 1. MapReduce概述2. MapReduce的功能2.1 数据划分和计算任务调度2.2 数据/代码互定位2.3 系统优化2.4 出错检测和恢复 3. MapReduce处理流程4. MapReduce编程基础参考 1. MapReduce概述 MapReduce是面向大数据并行处理的计算模型、框架和平台: 1. 基于集群的高性能并行…...
循环神经网络(RNN)+pytorch实现情感分析
目录 一、背景引入 二、网络介绍 2.1 输入层 2.2 循环层 2.3 输出层 2.4 举例 2.5 深层网络 三、网络的训练 3.1 训练过程举例 1)输出层 2)循环层 3.2 BPTT 算法 1)输出层 2)循环层 3)算法流程 四、循…...
Mac cursor设置jdk、Maven版本
基本配置 – Cursor 使用文档 首先是系统用户级别的设置参数,运行cursor,按下ctrlshiftp,输入Open User Settings(JSON),在弹出的下拉菜单中选中下面这样的: 在打开的json编辑器中追加下面的内容: {"…...
WPS数据分析000005
目录 一、数据录入技巧 二、一维表 三、填充柄 向下自动填充 自动填充选项 日期填充 星期自定义 自定义序列 1-10000序列 四、智能填充 五、数据有效性 出错警告 输入信息 下拉列表 六、记录单 七、导入数据 编辑 八、查找录入 会员功能 Xlookup函数 VL…...
CTF从入门到精通
文章目录 背景知识CTF赛制 背景知识 CTF赛制 1.web安全:通过浏览器访问题目服务器上的网站,寻找网站漏洞(sql注入,xss(钓鱼链接),文件上传,包含漏洞,xxe,ssrf,命令执行,…...
Flutter使用Flavor实现切换环境和多渠道打包
在Android开发中通常我们使用flavor进行多渠道打包,flutter开发中同样有这种方式,不过需要在原生中配置 具体方案其实flutter官网个了相关示例(https://docs.flutter.dev/deployment/flavors),我这里记录一下自己的操作 Android …...
Springboot如何使用面向切面编程AOP?
Springboot如何使用面向切面编程AOP? 在 Spring Boot 中使用面向切面编程(AOP)非常简单,Spring Boot 提供了对 AOP 的自动配置支持。以下是详细的步骤和示例,帮助你快速上手 Spring Boot 中的 AOP。 1. 添加依赖 首先ÿ…...
51单片机(STC89C52)开发:点亮一个小灯
软件安装: 安装开发板CH340驱动。 安装KEILC51开发软件:C51V901.exe。 下载软件:PZ-ISP.exe 创建项目: 新建main.c 将main.c加入至项目中: main.c:点亮一个小灯 #include "reg52.h"sbit LED1P2^0; //P2的…...
基于MinIO的对象存储增删改查
MinIO是一个高性能的分布式对象存储服务。Python的minio库可操作MinIO,包括创建/列出存储桶、上传/下载/删除文件及列出文件。 查看帮助信息 minio.exe --help minio.exe server --help …...
Ubuntu Server 安装 XFCE4桌面
Ubuntu Server没有桌面环境,一些软件有桌面环境使用起来才更加方便,所以我尝试安装桌面环境。常用的桌面环境有:GNOME、KDE Plasma、XFCE4等。这里我选择安装XFCE4桌面环境,主要因为它是一个极轻量级的桌面环境,适合内…...
浅谈 React Hooks
React Hooks 是 React 16.8 引入的一组 API,用于在函数组件中使用 state 和其他 React 特性(例如生命周期方法、context 等)。Hooks 通过简洁的函数接口,解决了状态与 UI 的高度解耦,通过函数式编程范式实现更灵活 Rea…...
java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别
UnsatisfiedLinkError 在对接硬件设备中,我们会遇到使用 java 调用 dll文件 的情况,此时大概率出现UnsatisfiedLinkError链接错误,原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用,结果 dll 未实现 JNI 协…...
ESP32 I2S音频总线学习笔记(四): INMP441采集音频并实时播放
简介 前面两期文章我们介绍了I2S的读取和写入,一个是通过INMP441麦克风模块采集音频,一个是通过PCM5102A模块播放音频,那如果我们将两者结合起来,将麦克风采集到的音频通过PCM5102A播放,是不是就可以做一个扩音器了呢…...
C++ 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...
【HTTP三个基础问题】
面试官您好!HTTP是超文本传输协议,是互联网上客户端和服务器之间传输超文本数据(比如文字、图片、音频、视频等)的核心协议,当前互联网应用最广泛的版本是HTTP1.1,它基于经典的C/S模型,也就是客…...
多模态大语言模型arxiv论文略读(108)
CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文标题:CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文作者:Sayna Ebrahimi, Sercan O. Arik, Tejas Nama, Tomas Pfister ➡️ 研究机构: Google Cloud AI Re…...
select、poll、epoll 与 Reactor 模式
在高并发网络编程领域,高效处理大量连接和 I/O 事件是系统性能的关键。select、poll、epoll 作为 I/O 多路复用技术的代表,以及基于它们实现的 Reactor 模式,为开发者提供了强大的工具。本文将深入探讨这些技术的底层原理、优缺点。 一、I…...
在WSL2的Ubuntu镜像中安装Docker
Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...
项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)
Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败,具体原因是客户端发送了密码认证请求,但Redis服务器未设置密码 1.为Redis设置密码(匹配客户端配置) 步骤: 1).修…...
使用LangGraph和LangSmith构建多智能体人工智能系统
现在,通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战,比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...
