来源:黄健宏
浏览 818
扫码
分享
2020-01-01 20:30:09
重点回顾
- Redis 服务器的所有数据库都保存在
redisServer.db
数组中,而数据库的数量则由 redisServer.dbnum
属性保存。 - 客户端通过修改目标数据库指针,让它指向
redisServer.db
数组中的不同元素来切换不同的数据库。 - 数据库主要由
dict
和 expires
两个字典构成,其中 dict
字典负责保存键值对,而 expires
字典则负责保存键的过期时间。 - 因为数据库由字典构成,所以对数据库的操作都是建立在字典操作之上的。
- 数据库的键总是一个字符串对象,而值则可以是任意一种 Redis 对象类型,包括字符串对象、哈希表对象、集合对象、列表对象和有序集合对象,分别对应字符串键、哈希表键、集合键、列表键和有序集合键。
expires
字典的键指向数据库中的某个键,而值则记录了数据库键的过期时间,过期时间是一个以毫秒为单位的 UNIX 时间戳。- Redis 使用惰性删除和定期删除两种策略来删除过期的键:惰性删除策略只在碰到过期键时才进行删除操作,定期删除策略则每隔一段时间,主动查找并删除过期键。
- 执行 SAVE 命令或者 BGSAVE 命令所产生的新 RDB 文件不会包含已经过期的键。
- 执行 BGREWRITEAOF 命令所产生的重写 AOF 文件不会包含已经过期的键。
- 当一个过期键被删除之后,服务器会追加一条 DEL 命令到现有 AOF 文件的末尾,显式地删除过期键。
- 当主服务器删除一个过期键之后,它会向所有从服务器发送一条 DEL 命令,显式地删除过期键。
- 从服务器即使发现过期键,也不会自作主张地删除它,而是等待主节点发来 DEL 命令,这种统一、中心化的过期键删除策略可以保证主从服务器数据的一致性。
- 当 Redis 命令对数据库进行修改之后,服务器会根据配置,向客户端发送数据库通知。
当前内容版权归
黄健宏 或其关联方所有,如需对内容或内容相关联开源项目进行关注与资助,请访问
黄健宏 .