Redis-13-Redis高并发常见问题

本文探讨了Redis在高并发场景下可能出现的缓存穿透、缓存击穿和缓存雪崩问题,以及对应的解决方案,如使用布隆过滤器、分布式锁、设置过期标志等。同时提到了分布式锁的实现及防止误删策略,确保系统稳定运行。

说明

  • Redis-13-Redis高并发常见问题
  • 主要包括:缓存穿透、缓存击穿、缓存雪崩、分布式锁
  • 官方文档:https://redis.io/documentation
  • Redis命令参考:http://redisdoc.com/

核心概念

》Redis高并发常见问题包括哪些?

  • 缓存穿透
    • 高并发反复请求Redis缓存和DB中都不存在的数据,导致DB崩溃
  • 缓存击穿
    • 是个瞬间状态,当Redis中某个key(热点key)失效的瞬间,高并发反复请求该key,导致全部请求到DB,导致DB崩溃
  • 缓存雪崩
    • 不明原因导致Redis中大量key瞬间失效,导致DB压力过大从而崩溃
  • 分布式锁

》解决方案

  • 缓存穿透
    • 对空值缓存
    • 设置白名单(使用Bitmaps)
    • 布隆过滤器(Bloom Filter)
    • 实时监控Redis
  • 缓存击穿
    • 预先设置热点数据
    • 实时调整热点key过期时间
    • 使用锁。先锁住(setnx)而不是立即去查DB
  • 缓存雪崩
    • 构建多级缓存(NGINX+Redis+其他)
    • 使用锁或队列
    • 设置过期标志(提前量),借助其他线程或服务监控过期标志提前触发更新缓存
    • 分散缓存失效时间,避免集中失效
  • 分布式锁
    • 使用setnx
    • 注意:使用时避免死锁,需要设置过期时间
    • 注意:使用时避免设置了锁但还未设置过期时间时崩溃导致死锁问题,可以使用如下命令:set k v ex 60 nx,加锁的同时设置过期时间

》其他问题

  • 如何防止分布式锁误删?
    • 误删触发场景:比如A进程上锁后进程卡死导致锁过期了还没触发释放,然后B进程进来了进行了加锁,A进程恢复后将B进程的锁释放
    • 解决方案:加锁时设置UUID,释放时进行判断UUID是否相等
Redis 提供了一系列工具和脚本以帮助用户更好地进行安装、测试、维护和性能评估。以下是对提到的工具和脚本的详细说明及其使用方式: ### `mkreleasehdr.sh` 脚本 `mkreleasehdr.sh` 是 Redis 源码构建过程中使用的一个脚本,主要负责生成版本头文件。它会根据 Git 仓库的信息生成 `version.h` 文件,该文件包含了当前 Redis 的版本号、Git 提交哈希值等元数据信息。这个脚本通常在 Redis 编译过程中自动运行,开发者无需手动调用它。如果手动需要运行,可以执行以下命令: ```bash ./mkreleasehdr.sh ``` 此脚本确保了 Redis 版本信息的动态生成,方便在不同环境中进行版本追踪和调试。 ### `redis-benchmark`:基准性能测试工具 `redis-benchmark` 是 Redis 自带的性能测试工具,用于评估 Redis 服务器的吞吐量、延迟等关键性能指标。它支持多种测试模式和选项,例如并发连接数、请求类型等。例如,测试本地 Redis 服务器的性能可以使用以下命令: ```bash redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 10000 ``` 其中 `-h` 指定服务器地址,`-p` 指定端口,`-c` 表示并发客户端数量,`-n` 表示请求数量。该工具特别适用于在部署前评估 Redis 的性能瓶颈或在调试时验证配置更改的影响[^3]。 ### `redis-check-aof`:AOF 持久化文件修复工具 `redis-check-aof` 用于检查和修复 Redis 的 AOF(Append-Only File)持久化文件。如果 Redis 因为异常关闭而导致 AOF 文件损坏,可以使用该工具进行恢复。例如: ```bash redis-check-aof appendonly.aof ``` 如果发现文件损坏,可以使用 `--fix` 选项进行修复: ```bash redis-check-aof --fix appendonly.aof ``` 该工具能够确保 AOF 文件的完整性,避免数据丢失或服务中断。 ### `redis-cli`:命令行客户端工具 `redis-cli` 是 Redis 的命令行客户端工具,用于与 Redis 服务器交互。它支持多种命令,例如设置键值对、查询数据、管理服务器配置等。例如,连接本地 Redis 服务器并设置一个键值对: ```bash redis-cli 127.0.0.1:6379> SET mykey "Hello Redis" OK 127.0.0.1:6379> GET mykey "Hello Redis" ``` 此外,`redis-cli` 还支持集群管理、哨兵模式配置等高级功能,是日常运维和调试的核心工具。 ### `redis-server`:启动 Redis 服务器 `redis-server` 是启动 Redis 服务器的主程序。默认情况下,它会读取配置文件(通常是 `redis.conf`)来启动实例。例如: ```bash redis-server /path/to/redis.conf ``` 配置文件中可以定义端口、持久化策略、日志路径等参数。如果需要启动多个 Redis 实例,可以通过不同的配置文件指定不同的端口和数据目录。 ### 工具常见问题及解决方案 1. **`redis-benchmark` 测试结果不准确** 可能由于网络延迟或服务器负载过高导致。建议在本地环境中进行测试,并确保服务器资源充足。 2. **`redis-check-aof` 无法修复文件** 如果 AOF 文件损坏严重,可能需要依赖备份文件进行恢复。建议定期备份 AOF 文件以防止数据丢失。 3. **`redis-cli` 无法连接服务器** 检查 Redis 服务器是否正在运行,以及防火墙是否允许相应端口通信。可以使用 `redis-cli ping` 命令测试连接状态。 4. **`redis-server` 启动失败** 检查配置文件中的参数是否正确,尤其是端口是否被占用、日志路径是否存在。可以通过查看日志文件定位问题。 ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值