redis如何保证数据都是热点数据

背景

众所周知,redis是纯内存的操作。所以速度极快。然而内存的大小是有限的。

如:mysql中有2000w的数据,redis中只存20w的数据,那么如何保证redis中的数据都是热点数据呢?

答案:redis内存数据集达到一定大小的时候,就会实行数据淘汰策略,内存的淘汰机制的初衷是为了更好地使用内存

写在淘汰策略之前:reids 过期策略

我们在设置一个key的时候,一般会给这个key设置一个过期时间(expire time),如:key的过期时间1小时,那么一小时到了,这个key是如何被删除的呢?

答案就是:定期删除+惰性删除

定期删除
指的是redis默认是每隔100ms就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除。注意,这里可不是每隔100ms就遍历所有的设置过期时间的key,那样就是一场性能上的灾难。实际上redis是每隔100ms随机抽取一些key来检查和删除的。定期删除可能会导致很多过期key到了时间并没有被删除掉,这时候就需要惰性删除了。

惰性删除
在获取某个key的时候,redis会检查一下 ,这个key如果设置了过期时间那么是否过期了?如果过期了此时就会删除,不会给你返回任何东西。

两种结合使用,就能够保证:一个key如果过期了,肯定会被删除了

但是,如果定期删除漏掉了很多过期key,然后也没及时去做查询,也就没走惰性删除,此时就可能会有大量过期key堆积在内存里,导致redis内存块耗尽
怎么办?

答案是:走内存淘汰机制

redis的淘汰策略:
  1. noeviction:内存满了之后,会返回异常。
  2. allkeys-lru:尝试回收,最近未使用或者使用比较少的键。(范围是:所有的键)
  3. volatile-lru:尝试回收,最近未使用或者使用比较少的键。(范围是:设置了过期时间的键)
  4. allkeys-random:随机移除某个key。(范围是:所有的键)
  5. volatile-random:随机移除某个key。(范围是:设置了过期时间的键)
  6. volatile-ttl:回收过期时间较短的key。(范围是:设置了过期时间的键)

本文参考了中华石杉

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于 Redis 热点数据缓存,可以使用 Redis 的缓存功能来提高系统性能和响应速度。热点数据指的是频繁被访问的数据,通过将这些数据缓存在内存中,可以避免频繁地从数据库中读取,从而减少数据库的压力。 在 Redis 中,可以使用以下两种常见的方式来实现热点数据缓存: 1. 缓存数据存储在 Redis 的字符串类型中:将需要缓存的数据序列化为字符串,并使用一个唯一的键来存储在 Redis 中。当需要访问该数据时,先从 Redis 中尝试获取,如果获取不到,则从数据库中读取,并将读取到的数据存储到 Redis 中以供下次使用。这样就可以实现数据的快速读取和缓存更新。 2. 缓存数据存储在 Redis 的哈希类型中:将需要缓存的数据组织为一个哈希表,其中每个字段对应一个属性或字段,并使用一个唯一的键来存储在 Redis 中。当需要访问该数据时,同样先从 Redis 中尝试获取,如果获取不到,则从数据库中读取,并将读取到的数据以哈希表的形式存储到 Redis 中。这种方式可以更灵活地处理复杂的数据结构。 需要注意的是,为了保证缓存的一致性和有效性,需要在适当的时机进行缓存的更新和失效操作。例如,在数据更新之后,需要及时更新 Redis 中的缓存数据,以保证缓存与数据库的一致性。另外,还可以设置合适的缓存过期时间,避免缓存数据过期但仍然被使用的情况发生。 总的来说,通过 Redis热点数据缓存可以提高系统的性能和响应速度,减少数据库的压力,但需要注意缓存的一致性和有效性的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值