美文网首页
Redis(3):Redis数据库结构以及键值删除策略

Redis(3):Redis数据库结构以及键值删除策略

作者: hcq0514 | 来源:发表于2023-09-05 15:14 被阅读0次

Redis的数据库结构,结构为

typedef struct redisDb {
    dict *dict;                 /* The keyspace for this DB */
    dict *expires;              /* Timeout of keys with a timeout set */
    dict *blocking_keys;        /* Keys with clients waiting for data (BLPOP) */
    dict *ready_keys;           /* Blocked keys that received a PUSH */
    dict *watched_keys;         /* WATCHED keys for MULTI/EXEC CAS */
    struct evictionPoolEntry *eviction_pool;    /* Eviction pool of keys */
    int id;                     /* Database ID */
    long long avg_ttl;          /* Average TTL, just for stats */
} redisDb;

Redis是一个KV类型的数据库,比较重要的属性为(dict,expires)

  • dict:保存了数据库里面所有的键值对

他是key都是字符串类型,值的话是对应的对象(字符串,列表,hash,set,zset)

  • expires:保存了所有key值的到期时间,定期删除也是基于这张表做的
存在过期键值的数据库例子

Redis过期键删除策略(惰性删除、定期删除、主动清除)

  • 惰性删除

在获取(写操作之前也会先读取一下)这个key的时候判断键是否过期,如果过期的话就进行删除,并且返回空

  • 定期删除

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

  • 主动清理(当前已用内存超过maxmemory限定时,触发主动清理策略)
在介绍删除策略之前先了解一下删除算法,LRU跟LFU
  1. LRU(Least Recently Used,最久未使用的)以最近一次访问时间作为参考,淘汰很久没被访问过的数据,
  2. LFU(Least Frequently Used,最不频繁使用的)以访问次数作为参考,淘汰最近一段时间被访问次数最少的数据
主动删除策略,主要有3个维度(a:对key有设置过期时间的 b:所有key,c:不处理)

(a) 针对设置了过期时间的key做处理:

  1. volatile-ttl(time-to-live):在筛选时,会针对设置了过期时间的键值对,根据过期时间的先后进行删除,越早过期的越先被删除。
  2. volatile-random:就像它的名称一样,在设置了过期时间的键值对中,进行随机删除。
  3. volatile-lru:会使用 LRU 算法筛选设置了过期时间的键值对删除。
  4. volatile-lfu:会使用 LFU 算法筛选设置了过期时间的键值对删除。

(b) 针对所有的key做处理:

  1. allkeys-random:从所有键值对中随机选择并删除数据。
  2. allkeys-lru:使用 LRU 算法在所有数据中进行筛选删除。
  3. allkeys-lfu:使用 LFU 算法在所有数据中进行筛选删除。

(c) 不处理:

  1. noeviction:不会剔除任何数据,拒绝所有写入操作并返回客户端错误信息"(error)
主动删除策略配置建议

当存在热点数据时,LRU的效率很好,但偶发性的、周期性的批量操作会导致LRU命中率急剧下
降,缓存污染情况比较严重。这时使用LFU可能更好点。
根据自身业务类型,配置好maxmemory-policy(默认是noeviction),推荐使用volatile-lru。如
果不设置最大内存,当 Redis 内存超出物理内存限制时,内存的数据会开始和磁盘产生频繁的交
换 (swap),会让 Redis 的性能急剧下降。
当Redis运行在主从模式时,只有主结点才会执行过期删除策略,然后把删除操作”del key”同
步到从结点删除数据。

相关文章

  • Redis入门

    @(数据库) Redis C语言开发的非关系型键值对数据库 1 基本介绍 redis 的数据结构redis存储的实...

  • Redis几种常见问题

    1.Redis的过期策略以及内存淘汰机制 Redis采用的是定期删除+惰性删除策略+内存淘汰机制。 定期删除,Re...

  • Redis 过期策略

    redis 过期策略 redis 过期策略是:定期删除+惰性删除。 所谓定期删除,指的是 redis 默认是每隔 ...

  • redis底层数据结构

    redis对象结构 注:本文基于redis3.0 redis是一种键值(key-value)数据库,键的数据类型是...

  • 【Redis】Redis中5种基础数据结构以及相应的命令行和Py

    本文主要介绍了Redis中5种基本的数据结构,以及相应的数据操作命令。 Redis基本数据结构 Redis是键值对...

  • Redis--(redis部署、基础命令及五种数据结构)

    01,Redis介绍 1,简介 Redis是一种基于键值对的NoSQL数据库,与很多键值对数据库不同,redis中...

  • 10.RDB持久化

    Redis是一个键值对数据库服务器,我们将服务器中的非空数据库以及它们的键值对统称为数据库状态。 Redis数据库...

  • Redis 总结

    Redis 底层数据结构 Redis 数据库里面的每个键值对(key-value)都是由对象(object)组成的...

  • Redis

    第1章 Redis介绍 1.1 Redis是什么 Redis是一种基于键值对的NoSQL数据库,与很多键值对数据库...

  • Redis

    第1章 Redis介绍 1.1 Redis是什么 Redis是一种基于键值对的NoSQL数据库,与很多键值对数据库...

网友评论

      本文标题:Redis(3):Redis数据库结构以及键值删除策略

      本文链接:https://www.haomeiwen.com/subject/mglhvdtx.html