-
要定位被淘汰的key,需监控evicted_keys增量、expired_keys飙升情况,并结合Redis7.0+的MEMORYUSAGE与OBJECTFREQ抽样分析;allkeys-lru不安全,应优先用volatile-lru/lfu;LFU更耗CPU因频次衰减更新;验证key是否频繁淘汰可用PFADD+PFCOUNT埋点统计。
-
Redis在SSD云盘上AOF重写或RDBsave卡顿,主因是文件系统磁盘屏障(barrier)强制全链路落盘,导致fsync延迟飙升;可通过mount和xfs_info检查barrier=1或data=ordered确认。
-
RPOPLPUSH是唯一能安全抢占List任务的原子操作,因其一步完成“从source弹出并推入destination”,避免LRPOP+LPUSH组合导致的任务丢失、重复或空返回误判。
-
缓存穿透本质是无效key频繁击穿至DB,需用BloomFilter在Redis层预检;其误判可控、内存极小,支持高效存在性判断;Redisson中应使用RBloomFilter并正确初始化,注意冷启动、误判率调优及数据一致性问题。
-
HSET查单个字段更快,SET写整条数据更省网络;字段少且固定用HSET,动态多变或需原子替换用SET;LIST队列易丢消息,推荐STREAM;ZSET排行榜慎用浮点score;大SET内存开销大,慎用SMEMBERS。
-
LTRIM是限制RedisList长度的唯一可靠方式,因其原子性、精准截断和内存即时释放特性;必须配合LPUSH使用,错误参数会清空列表,高并发下推荐Lua脚本保障原子性。
-
根本原因是COW导致RSS内存暴涨触碰maxmemory上限而被迫淘汰;bgsave时fork子进程触发Copy-On-Write,父进程修改内存页即复制物理页,临近maxmemory时瞬时内存增长直接触发淘汰。
-
大key在Redis主从同步中会触发复制断连,表现为从库state由online突变为offline、日志反复出现Connectionwithmasterlost和Resyncingfrommaster,根源是RDB/AOF传输超时或内存溢出。
-
min-slaves-to-write是主从切换丢数据时首要排查项,它控制主节点在合格从节点不足时拒绝写入,但需配合min-slaves-max-lag和真实复制状态(state=online、lag≤阈值)才生效。
-
主从节点淘汰策略必须完全一致,否则必然导致数据不一致;需统一maxmemory-policy、maxmemory值,确保read_only开启,并避免从节点写操作及运行时配置变更。
-
Redis单个STRING超10MB必须拆分,建议512KB内切片并用GETRANGE/SETRANGE操作;BigHash应按访问频次和语义拆为小Hash,禁用HGETALL;一致性靠Lua脚本或状态字段+重试保障。
-
PUBSUBNUMSUB命令可实时获取指定频道的活跃订阅者数量,返回整数(无人订阅时为0),支持多频道批量查询,但不区分SUBSCRIBE/PSUBSCRIBE,且在RedisCluster中需直连对应节点执行。
-
INCRBY不能直接用作全局唯一ID,因其在主从复制延迟、Redis重启无持久化、分片集群跨slot等场景下会导致ID重复或跳变;可靠方案是时间戳+原子自增组合,并需开启AOF、Lua封装、slot标签等保障措施。
-
redis-check-aof不能修复截断的AOF文件,仅校验并截断末尾不完整命令,使文件回退至最后一个完整写入点。
-
OBJECTFREQ返回key的LFU近似频次(0–255),多次GET后应上升;频次非线性增长、有衰减、依赖serverCron更新,需确认Redis≥4.0、maxmemory-policy正确配置且内存压力存在。