10道Java限流器面试题和答案

2023-12-19

分享关于限流器的10大Java面试问题。

微信搜索关注《Java学研大本营》

图片

1 什么是速率限制?

速率限制是指对用户在一定时间段内向系统发出的请求次数进行控制,以保证系统的稳定性和资源的公平分配。

2 如何使用Java实现基本的限流器?

可以使用令牌桶或滑动日志方法。

public class RateLimiter {
  private final long maxRequests;
  private long lastRequestTime = System.currentTimeMillis();
  private long currentRequests = 0;
  public RateLimiter(long maxRequestsPerSecond) {
    this.maxRequests = maxRequestsPerSecond;
  }
  public synchronized boolean allowRequest() {
    long currentTime = System.currentTimeMillis();
    if (currentTime - lastRequestTime > 1000) {
      lastRequestTime = currentTime;
      currentRequests = 0;
    }
    if (currentRequests < maxRequests) {
      currentRequests++;
      return true;
    }
    return false;
  }
}

3 令牌桶算法如何实现速率限制?

系统以一定的频率向桶里放入令牌。每个请求都要消耗一个令牌。如果桶里没有令牌,请求就会被拒绝。

图片

4 如何在速率限制中使用Redis?

Redis,凭借其原子操作和过期键,可以在分布式系统中高效地跟踪记录请求次数或令牌数量。

图片

Redis 可用于限制速率

5 如何处理分布式速率限制?

使用一个集中式存储,如Redis,或一个分布式配置系统,如ZooKeeper,来协调多个实例之间的速率限制。

图片

Redis 可处理分布式速率限制

图片

ZooKeeper 可处理分布式速率限制

6 有状态和无状态限流器有什么区别?

有状态的限流器会保存状态(比如请求次数),而无状态的限流器只根据当前的数据做出决策,不存储过去的信息。

无状态的限流器不会在请求之间保留任何状态,也就是说它不会记住之前的请求。它只是根据当前请求的信息做出决策。无状态限流器的一种常用方法是使用JWT(JSON Web Token)或类似的令牌,令牌里面包含了必要的信息。

下面是使用JWT的简单示例:

  • 客户端请求访问并接收一个JWT,其中包含过期时间和允许的最大请求数。

  • 对于每个请求,客户端发送JWT。

  • 服务器验证JWT,并检查过期时间和已发出的请求数。

  • 如果客户端在时间范围内超过了请求数,服务器拒绝请求。

下面是基本的实现:

import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import io.jsonwebtoken.Claims;

public class StatelessRateLimiter {
  private static final String SECRET_KEY = "mySecretKey";
  private static final int MAX_REQUESTS = 10;
  private static final int ONE_HOUR = 3600000;
  public String generateToken() {
    long expirationTime = System.currentTimeMillis() + ONE_HOUR;
    return Jwts.builder()
                  .setSubject("rateLimitToken")
                  .claim("requests", 0)
                  .setExpiration(new Date(expirationTime))
                  .signWith(SignatureAlgorithm.HS512, SECRET_KEY)
                  .compact();
  }
  public boolean allowRequest(String token) {
    try {
      Claims claims = Jwts.parser()
                              .setSigningKey(SECRET_KEY)
                              .parseClaimsJws(token)
                              .getBody();
      int requests = claims.get("requests", Integer.class);
      if (requests < MAX_REQUESTS) {
        claims.put("requests", requests + 1);
        return true;
      }
      return false;
    } catch (Exception e) {
      return false;
    }
  }
}

这是一个简化的例子。在实际场景中,你需要处理令牌的更新,确保令牌的安全存储,并管理其他安全方面。这里使用的JWT库是 jjwt

7 如何用Java实现一个滑动窗口限流器?

用一个列表或双端队列来存储请求的时间戳。保证在每个时间窗口内的请求次数不超过限制。

import java.util.Deque;
import java.util.LinkedList;

public class SlidingWindowRateLimiter {

    private final Deque<Long> timestamps;
    private final int maxRequests;
    private final long windowSizeInMillis;
  
    public SlidingWindowRateLimiter(int maxRequests, long windowSizeInMillis) {
        this.timestamps = new LinkedList<>();
        this.maxRequests = maxRequests;
        this.windowSizeInMillis = windowSizeInMillis;
    }

    public synchronized boolean allowRequest() {
        long currentTime = System.currentTimeMillis();

        // 移除当前窗口外的时间戳
        while (!timestamps.isEmpty() && timestamps.peekFirst() < currentTime - windowSizeInMillis) {
            timestamps.pollFirst();
        }

        // 检查是否添加一个新请求会超过最大限制
        if (timestamps.size() < maxRequests) {
            timestamps.addLast(currentTime);
            return true;
        }

        return false;
    }

    public static void main(String[] args) {
        SlidingWindowRateLimiter limiter = new SlidingWindowRateLimiter(5, 1000); // 每秒5个请求

        for (int i = 0; i < 10; i++) {
            System.out.println(limiter.allowRequest()); // 前5个为true,后5个为false
            try {
                Thread.sleep(200); //睡眠200毫秒
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

在这个例子中, SlidingWindowRateLimiter 限制了在一定时间窗口( windowSizeInMillis )内的最大请求次数( maxRequests )。 Deque 用于存储请求的时间戳。每次判断是否可以接受新请求时,它会先删除已经超出当前窗口的时间戳,然后再把 Deque 的长度和最大请求次数对比。

8 如何在微服务架构中处理速率限制?

在API网关层实现限流器或使用集中式存储来实现分布式速率限制方法。

9 在实时系统中进行速率限制有哪些挑战?

要求尽可能降低延迟,应对海量的请求,并在监控和执行限制的过程中不影响系统性能。

10 如何向用户或服务通知他们的速率限制状态?

使用HTTP头,如 X-RateLimit-Limit X-RateLimit-Remaining ,和 X-RateLimit-Reset 来传达速率限制的细节。

总结

速率限制是后端工程广阔领域中的一项重要技术,它能够保证系统的稳定性和资源的公平分配。我们已经了解了Java提供的各种工具和技术,可以用来实现有效的速率限制策略。无论你是准备面试,还是想要优化你的后端系统,掌握速率限制的细节都是非常必要的。建议你深入学习并进行实验。

推荐书单

《Java从入门到精通(第7版)(软件开发视频大讲堂)》

《Java从入门到精通(第7版)》从初学者角度出发,通过通俗易懂的语言、丰富多彩的实例,详细讲解了使用Java语言进行程序开发需要掌握的知识。全书分为4篇共24章,内容包括初识Java,开发工具(IDEA、Eclipse),Java语言基础,流程控制,数组,类和对象,继承、多态、抽象类与接口,包和内部类,异常处理,字符串,常用类库,集合类,枚举类型与泛型,lambda表达式与流处理,I/O(输入/输出),反射与注解,数据库操作,Swing程序设计,Java绘图,多线程,并发,网络通信,飞机大战游戏,MR人脸识别打卡系统。书中所有知识都结合具体实例进行讲解,涉及的程序代码都给出了详细的注释,这可以帮助读者轻松领会Java程序开发的精髓,并快速提高开发技能。

《Java从入门到精通(第7版)(软件开发视频大讲堂)》 icon-default.png?t=N7T8 https://item.jd.com/14067396.html

图片

精彩回顾

一文搞懂Java面向对象编程中的封装机制

一文搞懂Java面向对象编程中的继承机制

详解Java中的装饰器

5个Java开发者不可不知的编程库

用好这10个Spring Cloud功能,使用Java轻松开发微服务

微信搜索关注《Java学研大本营》

访问【IT今日热榜】,发现每日技术热

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

10道Java限流器面试题和答案 的相关文章

随机推荐

  • 广州软件第三方测试报告需要盖CNAS\CMA吗?怎么取费?

    CNAS CMA资质 1 CMA资质标识 根据报告接收方要求 第三方测试报告上是否加盖CMA标识 第三方测试机构执行标准为GB T25000 51和GB T25000 10标准 2 CNAS标识 ILAC MRA国际互认标识 通常第三方测试
  • SDN前沿技术【SMaRT-5G项目】

    目录 引言 节能方法 快速了解投资回报率 ROI ONF SMaRT 5G Initiative RAN 能量优化 方法 电池开 关方法 MIMO 睡眠和 RF 通道打开 关闭 高级睡眠模式 ASM RAN节能解决方案的
  • 【最新】2023年30米分辨率土地利用遥感监测数据

    改革开放以来 中国经济的快速发展对土地利用模式产生了深刻的影响 同时 中国又具有复杂的自然环境背景和广阔的陆地面积 其土地利用变化不仅对国家发展 也对全球环境变化产生了深刻的影响 为了恢复和重建我国土地利用变化的现代过程 更好地预测 预报土
  • Dubbo 注册中心挂了,consumer 还能不能调用 provider?

    在 Dubbo 中 如果注册中心 如 Zookeeper Nacos 等 出现故障 消费者 consumer 仍然可以调用提供者 provider 的服务 但需要满足以下条件 消费者和提供者之间的通信配置正确 消费者需要知道提供者的地址和端
  • Clion远程开发无法解析头文件,但是代码可以正常编译运行

    问题 当我在使用Clion进行远程开发时 需要用到Opencv库 我首先在CMakeLists txt添加了opencv库 如下 find package OpenCV REQUIRED INCLUDE DIRECTORIES OpenCV
  • 天眼情报分析——问题收集

    分为几类 一 代码实现问题 1 将两个字符串交替合并 这段代码错在逻辑错误 由于w1此时小于w2剩下的部分应该是w2而不是w1 我分析这位星友错误的原因应该是对底层逻辑实现没有深入理解 学到了不少 多多交流是好事 二 如何使用GitHub
  • NFS原理详解

    一 NFS介绍 1 什么是NFS 它的主要功能是通过网络让不同的机器系统之间可以彼此共享文件和目录 NFS服务器可以允许NFS客户端将远端NFS服务器端的共享目录挂载到本地的NFS客户端中 在本地的NFS客户端的机器看来 NFS服务器端共享
  • Java是怎么运行起来的?深入理解Java虚拟机

    介绍Java的工作原理和JVM的内部结构 微信搜索关注 Java学研大本营 Java虚拟机 JVM 是一个运行时环境 可以执行用Java编程语言编写的程序 Java语言是一种高级语言 它通过抽象和封装的机制 让开发者可以专注于业务逻辑和功能
  • 瑞芯微 rk3568的npu使用,部署unet网络

    文章目录 rk3568 1 6 0 1 在任一个ubuntu系统上安装RKNN Toolkit2 1 1 下载 1 2 安装 2 在机器端 板端 查看 RKNPU2的驱动 3 RKNN使用说明
  • Linux Centos 配置 Docker 国内镜像加速

    在使用 Docker 进行容器化部署时 由于国外的 Docker 镜像源速度较慢 我们可以配置 Docker 使用国内的镜像加速器 以提高下载和部署的效率 本文将介绍如何在 CentOS 系统上配置 Docker 使用国内镜像加速 步骤一
  • 南大通用的时间类型的使用解析

    示例sql create table TCK DATE TEXT id INTEGER not null date date DEFAULT TODAY
  • three.js关键帧动画KeyframeTrack、AnimationClip、AnimationMixer

    参考资料 threejs中文网 threejs qq交流群 814702116 关键帧动画 打开课件案例源码 你可以看到物体从一个位置移动到另一个位置的动画效果 移动过程中也出现过颜色变化 课件源码效果具体描述 就是 0 3秒 物体逐渐从坐
  • Android驱动并发与竞争

    下面介绍 原子操作 atomic t 自旋锁 spinlock t 信号量 semaphore 互斥体 mutex Android Linux是一个多任务操作系统 肯定会存在多个任务共同操作同一段内存或者设备的情况 多个任务甚至中断都能访问
  • IPQ4019 IPQ4029 IPQ5018 IPQ8072 IPQ6010 Wallys OpenWRT Compatible Routerboard Wallys|Industrial

    IPQ4019 IPQ4029 IPQ5018 IPQ8072 IPQ6010 Wallys OpenWRT Compatible Routerboard Wallys Industrial Commercial use Wallys Un
  • 机器学习之迁移学习(Transfer Learning)

    概念 迁移学习 Transfer Learning 是一种机器学习方法 其核心思想是将从一个任务中学到的知识应用到另一个相关任务中 传统的机器学习模型通常是从头开始训练 使用特定于任务的数据集 而迁移学习则通过利用已经在一个任务上学到的知识
  • 多线程案例:银行取钱

    不安全取钱 两个人去银行取钱 账户 银行取钱 给账户上锁 public class UnsafeBank public static void main String args 账户 Account3 account new Account
  • threejs关键帧动画播放(拖动任意时间状态)

    参考资料 threejs中文网 threejs qq交流群 814702116 动画播放 拖动任意时间状态 如果你想了解 关键帧动画在特定时间段播放 或者把动画定位在时间轴上任何一个时刻 或者借助UI拖动条 拖动查看关键帧任何时刻的状态 可
  • 【HarmonyOS】HarmonyOS参考资料

    HarmonyOS HarmonyOS参考资料 HarmonyOS参考资料 一 HarmonyOS应用开发者高级认证 二 HarmonyOS应用开发者基础认证考试 HarmonyOS参考资料 一 HarmonyOS应用开发者高级认证 Har
  • 在matlab和opencv中分别实现稀疏表示

    在本文中 稀疏表示的原理不再具体讲解 有需要的同学请自行百度 本文采用OMP算法来求解稀疏系数 首先随机生成字典数据和待测试数据 字典数据 dic 6 7 9 9 7 0 6 3 6 9 1 8 7 8 5 3 8 1 7 3 3 3 5
  • 10道Java限流器面试题和答案

    分享关于限流器的10大Java面试问题 微信搜索关注 Java学研大本营 1 什么是速率限制 速率限制是指对用户在一定时间段内向系统发出的请求次数进行控制 以保证系统的稳定性和资源的公平分配 2 如何使用Java实现基本的限流器 可以使用令