目录
Redis
数据类型
String、list、set、zset、hash
持久化策略
1.RDB:指定间隔内将数据集快照写进磁盘中的dump.rdb
2.AOF:以日志形式记录每个写操作,只运行追加不运行修改。
优先级AOF>RDB
如何实现分布式锁
加锁和解锁 加锁时设置过期时间 避免死锁
Set和Zset区别
set是无序的,底层逻辑是由hash和整数数组组成
Zset是有序的,底层原理是由Ziplist和跳表构成
Redis单线程架构
Redis的网络IO和键值对读写都是单线程的,而其他功能如持久化、异步删除等依赖其他线程来执行,单线程可以简化数据结构和算法实现,并且避免线程切换和竞争造成的消耗。
Redis的高可用
分为哨兵模式和集群模式,当主节点不可时,会选出一个从节点充当主节点,使用主从复制实现数据同步。
Redis缓存淘汰
惰性删除:客户端访问一个key时,redis会先检查它的过期时间如果发现过期则删除
定期删除:redis会将设置过期时间的Key保存在一个字典中软化每隔一段时间扫描一次。
Redis主从同步
主从同步是指任意数量的从节点都可以从主节点上同步数据。
当启动一个从节点的时候,它会发送一个psync命令给主节点。如果从节点是一次连接主节点,那么会触发一次全量复制。