Redis-单数据库的实现

1.reids默认有16个数据库,在

Redis-单数据库的实现

 

 2.数据库的键空间就是保存在dict字典里(所有的数据)

其他键空间的操作:exists,rename,keys

 

Redis-单数据库的实现

 


lru:计算键的闲置时间

设置过期时间:秒、毫秒、时间戳,最后都会转化为时间戳

2.expires字典保存了所有键的过期时间——过期字典

Redis-单数据库的实现

 

 实际中,键空间和过期字典都是指向同一个键对象。

presist命令去除过期字典中的健值

3.过期策略:

  定时:cpu不友好

    惰性:内存不友好

  定期:整合和折中的方法

要合理的设置定期删除的时长和执行频率

惰性删除实现:

  所有读写命令执行之前都会调用db.c/expireIfNeeded,如果过期删除,不过期,该函数不做动作

定期删除实现:

  在规定的时间内,分多次遍历服务器中的各个数据库,从过期字典中随机检查一部分的过期时间,并删除其中的过期键

  默认:数据库16个、每个数据库过期键20个,如果达到时间上线,停止处理

 

Redis-单数据库的实现

上一篇:sql优化案例(filter)


下一篇:MySQL主从复制详解