Redis的内存淘汰策略

本文介绍了如何查看和设置Redis的最大内存大小,包括通过`config get maxmemory`和配置文件进行配置。此外,详细阐述了Redis的内存淘汰策略,如noeviction、allkeys-lru等,并解释了各种策略的适用场景。最后,讨论了Redis可能导致的缓存问题,如缓存雪崩、缓存击穿和缓存穿透,提出了相应的解决方案,如设置随机过期时间、使用分布式锁等。
摘要由CSDN通过智能技术生成

占用内存大小

  1. 查看redis占用的最大内存
>config get maxmemory
  1. 设置redis占用的最大内存
#永久改变
config set maxmemory 100mb

另外也可通过配置文件修改,在配置文件redis.windows-service.conf中添加如下设置内存大小
maxmemory 100mb

如果不设置最大内存大小或者设置最大内存大小为0,在64位操作系统下不限制内存大小,在32位操作系统下最多3GB内存(建议设置为物理机最大内存的3/4)

Redis内存淘汰策略

当redis分配的最大内存用完时,继续往Redis里面添加数据就没内存可用了,Redis定义了几种策略来处理这种情况:

  1. noeviction(默认策略):对于写请求不再提供服务,直接返回错误。
  2. allkeys-lru:从所有key中删除最近最少使用的key
  3. allkeys-random:从所有key中随机删除key
  4. volatile-lru:从设置了过期key中使用LRU算法进行淘汰
  5. volatile-random:从设置了过期时间的key中随机淘汰
  6. volatile-ttl:在设置了过期时间的key中,根据key的过期时间进行淘汰。
    注意:当使用volatile-lru、volatile-random、volatile-ttl这三种策略时,如果没有key可以被淘汰,则和noeviction一样返回错误。

查看及设置淘汰策略

  1. 获取当前内存淘汰策略
127.0.0.1:6379> config get maxmemory-policy
  1. 通过配置文件设置淘汰策略,添加如下:
    maxmemory-policy allkeys-lru

  2. 通过命令修改淘汰策略

127.0.0.1:6379> config set maxmemory-policy allkeys-lru

Redis存在的问题

  1. 缓存雪崩
    大量的key或热点数据同时过期,导致针对这些key的大量请求同时请求到DB,导致数据库压力过大,甚至挂掉。
    解决:搭建redis集群;key的过期时间设置随机值。

  2. 缓存击穿
    针对缓存中没有但数据库有的数据,当一个热点的Key失效后,瞬间有大量的请求,来请求这一个Key,这些请求不会命中Redis,都会请求到DB,导致数据库压力过大,甚至挂掉。
    解决:设置热点key永不过期;分布式互斥锁重建缓存,获取缓存数据不存在时,加锁请求DB重建缓存。

  3. 缓存穿透
    针对缓存&数据库都不存在的数据,每次请求都会绕过缓存,直接来到数据库,并且查询不到结果,最终不会写入缓存。这样每次请求都去查询数据库,失去了缓存的意义。
    这类的请求量特别大时,会导致数据库压力过大,甚至挂掉。
    如,发起大量的id为“-1”的请求, 这样的用户很可能是攻击者,会导致数据库压力过大,甚至挂掉。
    解决:查询DB为空时,设置key-null,过期时间设置短些;接口层设置参数校验。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

laufing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值