Java中Redis面试题集锦(含过期策略详解)

news2025/6/3 9:13:50

🤟致敬读者

  • 🟩感谢阅读🟦笑口常开🟪生日快乐⬛早点睡觉

📘博主相关

  • 🟧博主信息🟨博客首页🟫专栏推荐🟥活动信息

文章目录

      • Java中Redis面试题集锦(含过期策略详解)
        • **一、Redis基础**
        • **二、过期策略详解(重点)**
        • **三、高级特性**
        • **四、Java生态整合**
        • **五、性能优化**
      • 面试回答技巧:过期策略


📃文章前言

  • 🔷文章均为学习工作中整理的笔记。
  • 🔶如有错误请指正,共同学习进步。

Java中Redis面试题集锦(含过期策略详解)


一、Redis基础
  1. Redis支持哪些数据类型?在Java中如何操作?

    • 数据类型:String、List、Set、SortedSet、Hash、Bitmap等
    • Java操作示例(Jedis):
      Jedis jedis = new Jedis("localhost");
      jedis.set("key", "value");                        // String
      jedis.lpush("list", "item1", "item2");            // List
      jedis.hset("user:1", "name", "Alice");            // Hash
      
  2. Redis单线程为何高性能?

    • 内存操作 + IO多路复用 + 避免上下文切换
    • 单线程处理命令保证原子性

二、过期策略详解(重点)
  1. Redis的键过期删除策略是什么?

    • 惰性删除:访问时检查过期并删除
      // Jedis访问时触发惰性删除
      String value = jedis.get("expired_key"); // 返回null
      
    • 定期删除:周期性随机扫描过期键(默认10次/秒)
      • 每次抽查20个键,删除过期键
      • 若过期键比例>25%,重复扫描
  2. Java中如何设置键过期?

    jedis.setex("temp_session", 300, "data");  // 300秒后过期
    jedis.expire("cache_key", 60);             // 60秒后过期
    jedis.pexpire("key", 10000L);              // 毫秒级过期
    
  3. 内存淘汰策略如何与过期键交互?

    策略是否涉及过期键Java配置示例
    volatile-lru仅淘汰有过期时间的键config.setMaxMemoryPolicy("volatile-lru")
    volatile-ttl优先淘汰TTL最短的键
    allkeys-lru所有键(含无过期时间)
  4. 主从模式下过期键如何处理?

    • 从节点不主动删除,依赖主节点同步DEL命令
    • Java代码需确保在主节点操作过期键

三、高级特性
  1. 如何用Redis实现分布式锁?

    // Redisson实现
    RLock lock = redisson.getLock("order_lock");
    lock.lock(30, TimeUnit.SECONDS); // 设置锁过期时间
    try {
      // 业务逻辑
    } finally {
      lock.unlock();
    }
    
  2. 缓存穿透/雪崩/击穿解决方案

    • 穿透:布隆过滤器 + 空值缓存
      if (jedis.get(key) == null) {
          jedis.setex(key, 300, ""); // 缓存空值
      }
      
    • 雪崩:随机过期时间
      jedis.setex(key, 60 + new Random().nextInt(30), value);
      
    • 击穿:互斥锁
      if (jedis.setnx("lock_key", "1") == 1) {
          jedis.expire("lock_key", 5); // 获取锁
      }
      

四、Java生态整合
  1. Spring Boot中如何配置Redis过期时间?

    spring:
      redis:
        timeout: 5000
        lettuce:
          pool:
            max-active: 8
    
    @Bean
    public RedisCacheManager cacheManager(RedisConnectionFactory factory) {
      RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
          .entryTtl(Duration.ofMinutes(30)); // 全局过期时间
    }
    
  2. Redis事务 vs Lua脚本

    • 事务:
      jedis.watch("key");
      Transaction tx = jedis.multi();
      tx.set("key1", "value1");
      tx.expire("key1", 60);
      tx.exec();
      
    • Lua脚本(原子操作):
      String script = "redis.call('SET', KEYS[1], ARGV[1]); " +
                     "redis.call('EXPIRE', KEYS[1], ARGV[2]);";
      jedis.eval(script, 1, "key", "value", "60");
      

五、性能优化
  1. 大Key过期导致阻塞怎么办?

    • 启用异步删除(Redis 6.0+):
      # redis.conf
      lazyfree-lazy-expire yes
      
    • Java拆分大Key:
      // 将大Hash拆分为多个小Key
      for (int i=0; i<100; i++) {
        jedis.hset("user:1:part" + i, "field", "value");
      }
      
  2. 如何监控过期键?

    // 获取过期键统计
    String info = jedis.info("stats");
    // expired_keys: 累计过期键数量
    // evicted_keys: 内存淘汰键数量
    

面试回答技巧:过期策略

当被问到Redis过期策略时,按层次回答:

  1. 核心机制:惰性删除 + 定期删除
  2. 存储结构:过期字典(Expires Dictionary)
  3. 持久化影响
    • RDB:持久化时不保存过期键
    • AOF:记录DEL命令
  4. 集群特性:主节点控制删除,从节点被动同步
  5. Java实践
    • 合理设置TTL避免堆积
    • 监控expired_keys指标
    • 大Key使用异步删除

示例回答
“Redis采用惰性删除和定期删除组合策略。当访问键时会触发惰性删除,同时Redis每秒10次随机扫描过期键。在Java中,我们通过setex()设置过期,结合volatile-ttl策略优化内存。对于大Key,建议启用Redis 6.0的异步删除避免阻塞主线程。”


通过这些问题,面试官可以全面考察你对Redis在Java中的应用能力,特别是对过期机制的深入理解。



📜文末寄语

  • 🟠关注我,获取更多内容。
  • 🟡技术动态、实战教程、问题解决方案等内容持续更新中。
  • 🟢《全栈知识库》技术交流和分享社区,集结全栈各领域开发者,期待你的加入。
  • 🔵​加入开发者的《专属社群》,分享交流,技术之路不再孤独,一起变强。
  • 🟣点击下方名片获取更多内容🍭🍭🍭👇

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2394863.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Maven 安装与配置指南(适用于 Windows、Linux 和 macOS)

Apache Maven 是一款广泛应用于 Java 项目的项目管理和构建工具。 本文提供在 Windows、Linux 和 macOS 系统上安装与配置 Maven 的详细步骤&#xff0c;旨在帮助开发者快速搭建高效的构建环境。 一、前置条件&#xff1a;安装 Java Development Kit (JDK) Maven 依赖于 Java …

android 媒体框架之MediaCodec

一、MediaCodec 整体架构与设计思想 MediaCodec 是 Android 底层多媒体框架的核心组件&#xff0c;负责高效处理音视频编解码任务。其架构采用 生产者-消费者模型&#xff0c;通过双缓冲区队列&#xff08;输入/输出&#xff09;实现异步数据处理&#xff1a; 输入缓冲区队列…

堆与堆排序及 Top-K 问题解析:从原理到实践

一、堆的本质与核心特性 堆是一种基于完全二叉树的数据结构&#xff0c;其核心特性为父节点与子节点的数值关系&#xff0c;分为大堆和小堆两类&#xff1a; 大堆&#xff1a;每个父节点的值均大于或等于其子节点的值&#xff0c;堆顶元素为最大值。如: 小堆&#xff1a;每个…

软件锁:守护隐私,安心无忧

数字化时代&#xff0c;手机已成为我们生活中不可或缺的一部分&#xff0c;它不仅存储着我们的个人信息、照片、聊天记录等重要数据&#xff0c;还承载着我们的社交、娱乐和工作等多种功能。然而&#xff0c;这也意味着手机上的隐私信息面临着诸多泄露风险。无论是家人、朋友还…

无人机桥梁3D建模、巡检、检测的航线规划

无人机桥梁3D建模、巡检、检测的航线规划 无人机在3D建模、巡检和检测任务中的航线规划存在显著差异&#xff0c;主要体现在飞行高度、航线模式、精度要求和传感器配置等方面。以下是三者的详细对比分析&#xff1a; 1. 核心目标差异 任务类型主要目标典型应用场景3D建模 生成…

【Java基础05】面向对象01

文章目录 1. 设计对象并使用1.1 类与对象1.2 封装1.2.1 private关键字1.2.2 this关键字成员变量和局部变量的区别 1.2.3 构造方法1.2.4 标准JavaBean类 1.3 对象内存图 本文部分参考这篇博客 1. 设计对象并使用 1.1 类与对象 public class 类名{1、成员变量(代表属性,一般是名…

设计模式:观察者模式 - 实战

一、观察者模式场景 1.1 什么是观察者模式&#xff1f; 观察者模式&#xff08;Observer Pattern&#xff09;观察者模式是一种行为型设计模式&#xff0c;用于定义一种一对多的依赖关系&#xff0c;当对象的状态发生变化时&#xff0c;所有依赖于它的对象都会自动收到通知并更…

YOLOv8 移动端升级:借助 GhostNetv2 主干网络,实现高效特征提取

文章目录 引言GhostNetv2概述GhostNet回顾GhostNetv2创新 YOLOv8主干网络改进原YOLOv8主干分析GhostNetv2主干替换方案整体架构设计关键模块实现 完整主干网络实现YOLOv8集成与训练模型集成训练技巧 性能对比与分析计算复杂度对比优势分析 部署优化建议结论与展望 引言 目标检…

国产化Word处理控件Spire.Doc教程:在 C# 中打印 Word 文档终极指南

在 C# 中以编程方式打印 Word 文档可以简化业务工作流程、自动化报告和增强文档管理系统。本指南全面探讨如何使用Spire.Doc for .NET打印 Word 文档&#xff0c;涵盖从基本打印到高级自定义技术的所有内容。我们将逐步介绍每种情况下的实际代码示例&#xff0c;确保您能够在实…

谷歌:贝叶斯框架优化LLM推理反思

&#x1f4d6;标题&#xff1a;Beyond Markovian: Reflective Exploration via Bayes-Adaptive RL for LLM Reasoning &#x1f310;来源&#xff1a;arXiv, 2505.20561 &#x1f31f;摘要 通过强化学习 (RL) 训练的大型语言模型 (LLM) 表现出强大的推理能力和紧急反射行为&a…

Qt SQL模块基础

Qt SQL模块基础 一、Qt SQL模块支持的数据库 官方帮助文档中的Qt支持的数据库驱动如下图&#xff1a; Qt SQL 模块中提供了一些常见的数据库驱动&#xff0c;包括网络型数据库&#xff0c;如Qracle、MS SQL Server、MySQL等&#xff0c;也包括简单的单机型数据库。 Qt SQL支…

[9-3] 串口发送串口发送+接收 江协科技学习笔记(26个知识点)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26中断

如何在Qt中绘制一个带有动画的弧形进度条?

如何在Qt中绘制一个弧形的进度条 在图形用户界面开发中&#xff0c;进度指示控件&#xff08;Progress Widget&#xff09;是非常常见且实用的组件。CCArcProgressWidget 是一个继承自 QWidget 的自定义控件&#xff0c;用于绘制圆弧形进度条。当然&#xff0c;笔者看了眼公开…

国产三维CAD皇冠CAD(CrownCAD)建模教程:汽车电池

在线解读『汽车电池』的三维建模流程&#xff0c;讲解3D草图、保存实体、拉伸凸台/基体、设置外观等操作技巧&#xff0c;一起和皇冠CAD&#xff08;CrownCAD&#xff09;学习制作步骤吧&#xff01; 汽车电池&#xff08;通常指铅酸蓄电池或锂离子电池&#xff09;是车辆电气系…

VMware-workstation安装教程--超详细(附带安装包)附带安装CentOS系统教程

VMware-workstation安装教程--超详细&#xff08;附带安装包&#xff09;附带安装CentOS系统教程 一、下载软件VMwware二、下载需要的镜像三、在VMware上安装系统 一、下载软件VMwware 二、下载需要的镜像 三、在VMware上安装系统 VMware 被 Broadcom&#xff08;博通&#x…

2025年- H63-Lc171--33.搜索旋转排序数组(2次二分查找,需二刷)--Java版

1.题目描述 2.思路 输入&#xff1a;旋转后的数组 nums&#xff0c;和一个整数 target 输出&#xff1a;target 在 nums 中的下标&#xff0c;如果不存在&#xff0c;返回 -1 限制&#xff1a;时间复杂度为 O(log n)&#xff0c;所以不能用遍历&#xff0c;必须使用 二分查找…

3D-激光SLAM笔记

目录 定位方案 编译tbb ros2humble安装 命令 colcon commond not found 栅格地图生成&#xff1a; evo画轨迹曲线 安装gtsam4.0.2 安装ceres-solver1.14.0 定位方案 1 方案一&#xff1a;改动最多 fasterlio 建图&#xff0c;加闭环优化&#xff0c;参考fast-lio增加关…

HomeKit 基本理解

概括 HomeKit 将用户的家庭自动化信息存储在数据库中&#xff0c;该数据库由苹果的内置iOS家庭应用程序、支持HomeKit的应用程序和其他开发人员的应用程序共享。所有这些应用程序都使用HomeKit框架作为对等程序访问数据库. Home 只是相当于 HomeKit 的表现层,其他应用在实现 …

(LeetCode 每日一题) 909. 蛇梯棋 (广度优先搜索bfs)

题目&#xff1a;909. 蛇梯棋 思路&#xff1a;广度优先搜索bfs队列&#xff0c;时间复杂度0(6*n^2)。 细节看注释 C版本&#xff1a; class Solution { public:int snakesAndLadders(vector<vector<int>>& board) {int nboard.size();// vis[i]&#xff1a;…

生成https 证书步骤

一、OpenSSL下载 OpenSSL下载地址&#xff1a; https://slproweb.com/products/Win32OpenSSL.html 如果电脑是64位的就选择64位的 二、OpenSSL安装 双击打开.exe文件 开始安装&#xff0c;一直下一步&#xff0c;不过需要注意的是默认安装路径是C盘&#xff0c;可更改到其他盘…