当前位置: 首页 > news >正文

Redis面试问题详解2

Redis面试问题详解2

一、分布式锁

分布式锁主要用于解决多服务器之间的并发问题。Redis通过SETNX命令实现分布式锁,确保同一时间只有一个线程可以获取锁。

1. 基本实现

获取锁

使用SETNX命令设置锁,并设置一个过期时间,避免死锁。

String lockKey = "lock:" + key;
if (redis.setnx(lockKey, "1", 30) == 1) { // 尝试获取锁,超时30秒// 执行业务逻辑
} else {// 等待锁释放Thread.sleep(100);
}

释放锁

使用DEL命令释放锁。

redis.del(lockKey);

2. watchdog(看门狗)机制

watchdog是Redisson提供的一种自动续期机制,用于防止锁因为超时而被误释放。它通过后台线程定期向Redis发送续期请求。

1、自动续期

当一个线程获取锁后,watchdog会启动一个后台线程,定期向Redis发送续期请求。

2、续期频率
续期频率通常设置为锁超时时间的一半。例如,如果锁的超时时间是30秒,watchdog会每15秒发送一次续期请求。

3、释放锁
当业务逻辑执行完成后,watchdog会自动停止续期,并释放锁。

代码示例

import org.redisson.api.RLock;
import org.redisson.api.RedissonClient;
import org.redisson.config.Config;public class DistributedLockExample {public static void main(String[] args) {// 配置RedissonConfig config = new Config();config.useSingleServer().setAddress("redis://127.0.0.1:6379");RedissonClient redisson = Redisson.create(config);// 获取锁RLock lock = redisson.getLock("lockKey");try {// 获取锁,自动续期lock.lock();// 执行业务逻辑System.out.println("执行业务逻辑...");Thread.sleep(10000); // 模拟长时间的业务逻辑} finally {// 释放锁lock.unlock();}// 关闭Redissonredisson.shutdown();}
}

实际应用场景

假设我们有一个库存扣减的场景,需要确保同一时间只有一个线程可以扣减库存:

public void deductStock(String productId, int quantity) {String lockKey = "lock:stock:" + productId;RLock lock = redisson.getLock(lockKey);try {lock.lock();// 查询库存int currentStock = database.getStock(productId);if (currentStock >= quantity) {// 扣减库存database.updateStock(productId, currentStock - quantity);System.out.println("库存扣减成功");} else {System.out.println("库存不足");}} finally {lock.unlock();}
}

3. 可重入性

分布式锁支持同一线程的重入,避免死锁。Redisson默认支持可重入锁,允许多次获取和释放同一把锁。

public void nestedLockExample() {String lockKey = "lock:nested";RLock lock = redisson.getLock(lockKey);try {lock.lock();System.out.println("第一次获取锁");// 再次获取锁lock.lock();System.out.println("第二次获取锁");} finally {lock.unlock();System.out.println("第一次释放锁");lock.unlock();System.out.println("第二次释放锁");}
}

二、主从复制

主从复制用于解决Redis的高并发问题,通过主节点负责写操作,从节点负责读操作,提高系统的读写能力。

1. 全量同步

全量同步是指从节点一次性同步主节点的所有数据。

操作步骤

  1. 从节点向主节点发送REPLCONFoffset
  2. 主节点通过BGSAVE生成RDB文件并发送给从节点。
  3. 在RDB生成期间,主节点将操作记录到缓存中。
  4. 主节点将缓存中的操作发送给从节点执行。

2. 增量同步

增量同步是指主节点将未同步的操作发送给从节点。

操作步骤

  1. 从节点向主节点发送REPLCONFoffset
  2. 主节点根据offset判断需要同步的内容。
  3. 主节点将未同步的操作发送给从节点执行。

3. 代码示例

# 主节点配置
slaveof <主节点IP> <主节点端口>

4. 策略对比

策略优点缺点适用场景
全量同步数据一致性高初始同步时间长第一次同步或数据不一致时
增量同步同步速度快依赖之前的同步状态数据部分不一致时

三、哨兵模式

哨兵模式用于解决Redis的高可用问题。当主节点出现故障时,哨兵会选举一个从节点升级为主节点。

1. 工作原理

  1. 主观下线:单个哨兵判断主节点下线。
  2. 客观下线:多个哨兵(超过半数)确认主节点下线。
  3. 选举新主节点:哨兵通过投票机制选举新的主节点。

2. 代码示例

# 配置哨兵
sentinel monitor <主节点名称> <主节点IP> <主节点端口> <哨兵数量>
sentinel down-after-milliseconds <主节点名称> 5000
sentinel parallel-syncs <主节点名称> 1
sentinel failover-timeout <主节点名称> 60000

四、分片集群

分片集群用于解决高并发写操作和海量数据存储问题。通过将数据分布到多个主节点,提高系统的读写能力。

1. Hash槽

Redis集群有16384个槽,每个Key通过哈希算法映射到一个槽。这种设计确保数据均匀分布,提高集群的扩展性。

2. 分片存储

每个主节点负责一部分槽,数据通过槽分布到不同的节点。这种分片机制允许集群处理更大的数据量和更高的并发请求。

3. 主从监督

主节点通过PING相互监督,确保高可用性。如果某个主节点出现故障,其他节点可以快速检测并进行故障转移。

五、Redis缓存为什么速度这么快

  1. 纯内存操作:所有数据存储在内存中,读写速度快。
  2. 单线程模型:避免了多线程的上下文切换开销。
  3. IO多路复用:通过epoll机制高效处理多个连接。
  4. 多线程优化:Redis 6.0引入多线程处理命令,提高性能。

1. IO多路复用

IO多路复用通过一个线程监控多个socket,当某个socket有请求时,线程会立即处理该请求。Redis使用epoll模式实现IO多路复用,显著提高了性能。

2. 多线程优化

Redis 6.0引入多线程处理命令,命令的接受和转发改为多线程方式,而核心数据结构操作仍保持单线程。

3. 代码示例

// Redis配置
redis {threads 8io-threads 4io-threads-do-reads yes
}

4. 策略对比

策略优点缺点适用场景
单线程模型简化并发控制无法充分利用多核CPU通用场景
IO多路复用高效处理多个连接实现复杂高并发场景
多线程优化提高命令处理速度仅适用于部分命令Redis 6.0及以上版本

还有部分内容参考之前写的Redis面试问题缓存相关详解-CSDN博客

相关文章:

  • 开源一体化白板工具Drawnix本地部署打造毫秒级响应的远程协作空间
  • win10和win11系统修复工具各类故障解决
  • DevOps-文章目录
  • Linux 防火墙( iptables )
  • 全球6G大会 | 紫光展锐用“芯”推动空天地一体创新纪元
  • 2025.4.17学习日记 初识JavaScript 以及Java和JavaScript有什么区别
  • [漏洞篇]CSRF漏洞详解
  • visual Studio+Qt插件检查内存泄漏
  • opencv HSV的具体描述
  • div(HTML标准元素)和view(微信小程序专用组件)的主要区别体
  • FPGA入门学习Day1——设计一个DDS信号发生器
  • Python开发环境打包迁移指南:离线与在线环境的完美解决方案
  • 数据结构之BFS广度优先算法(腐烂的苹果)
  • 【c语言】——深入理解指针2
  • 【模块化拆解与多视角信息6】自我评价:人设构建的黄金50字——从无效堆砌到精准狙击的认知升级
  • 【力扣】重排链表
  • C++ static的使用方法及不同作用
  • 你知道微生物是如何调控植物功能基因的吗?
  • 供水公司一体化抄表营业收费系统
  • 在 Kali Linux 上安装 Java OpenJDK 8(详细指南)
  • 普雷沃斯特当选新一任天主教罗马教皇
  • 视频丨习近平主席专机抵达莫斯科,俄战机升空护航
  • 前瞻|美联储明晨“按兵不动”几无悬念:关税战阴霾下,会否释放降息信号
  • 最新研究:基因编辑治疗晚期胃肠道癌显成效
  • 潘功胜:将下调个人住房公积金贷款利率0.25个百分点
  • 特朗普关税风暴中的“稳”与“变”:新加坡国会选举观察