浅谈Redis中的内存淘汰策略和过期键删除策略
而且我们都知道redis是一个完全基于内存的工具,这也是redis速度快的一个原因,当我们往redis中不断缓存数据的时候,其内存总有满的时候(而且内存是很贵的东西,尽量省着点用),所以尽可能把有用的数据,或者使用频繁的数据缓存在redis中,物尽其用。
那么如果正在使用的redis内存用完了,我们应该怎么取舍redis中已存在的数据和即将要存入的数据呢,我们要怎么处理呢?
redis官方提供了8种不同的淘汰策略
redis.conf 是个好东西,几乎redis的所有配置都可以在这里找到,根据conf中的说明也就能操作了
我们看下redis.conf中关于8中淘汰策略的说明(本文使用redis版本是4.0.9)
volatile-lru - Evict using approximated LRU among the keys with an expire set.
allkeys-lru - Evict any key using approximated LRU.
volatile-lfu - Evict using approximated LFU among the keys with an expire set.
allkeys-lfu - Evict any key using approximated LFU.
volatile-random - Remove a random key among the ones with an expire set.
allkeys-random - Remove a random key, any key.
volatile-ttl - Remove the key with the nearest expire time (minor TTL)
noeviction - Don t evict anything, just return an error on write operations.
# LRU means Least Recently Used(最近最少使用的,时间)
# LFU means Least Frequently Used(最不经常使用的,次数)
# The default is:
maxmemory-policy noeviction
上文是从redis.conf中摘出来关于淘汰策略的8种配置以及设置说明,其中maxmemory-policy noeviction 代表了淘汰策略默认的是noeviction,我们可以根据自己的业务需求修改合适的策略。
英文看不懂的看下面的中文
上面是内存不足的淘汰策略,还有一种是过期键的删除策略,两者是不同,不要搞混了
过期键的删除策略 定时过期:每个设置过期时间的key都需要创建一个定时器,到过期时间就会立即清除。该策略可以立即清除过期的数据,对内存很友好;但是会占用大量的CPU资源去处理过期的数据,从而影响缓存的响应时间和吞吐量。 惰性过期:只有当访问一个key时,才会判断该key是否已过期,过期则清除。该策略可以最大化地节省CPU资源,却对内存非常不友好。极端情况可能出现大量的过期key没有再次被访问,从而不会被清除,占用大量内存。 定期过期:每隔一定的时间,会扫描一定数量的数据库的expires字典中一定数量的key,并清除其中已过期的key。该策略是前两者的一个折中方案。通过调整定时扫描的时间间隔和每次扫描的限定耗时,可以在不同情况下使得CPU和内存资源达到最优的平衡效果。expires字典会保存所有设置了过期时间的key的过期时间数据,其中,
key是指向键空间中的某个键的指针,
value是该键的毫秒精度的UNIX时间戳表示的过期时间。
键空间是指该Redis集群中保存的所有键。
Redis的内存淘汰策略的选取并不会影响过期的key的处理。内存淘汰策略用于处理内存不足时的需要申请额外空间的数据;过期策略用于处理过期的缓存数据。
到此这篇关于浅谈Redis中的内存淘汰策略和过期键删除策略的文章就介绍到这了,更多相关Redis内存淘汰和过期键删除内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 浅谈Redis中的内存淘汰策略和过期键删除策略
相关文章
- 内存Redis:让自动内存释放成为可能(redis自动释放)
- Redis设置内存限制(redis限制大小)
- 善用Redis,构建高性能内存数据库(redis内存数据库)
- Redis:基于内存的数据库之路(redis内存数据库)
- Redis:精准的内存数据库存储(redis内存数据库)
- 如何快速清空Redis的所有数据(redis删除所有数据)
- 如何快速高效地在Redis中删除大量数据?(redis删除大量数据)
- 云Redis让内存大小成为可选择的抉择(云redis多大内存合适)
- SSM框架下使用Redis快速实现数据刷新(ssm刷新redis)
- 众筹Redis到底能不能用(众筹可以用到redis吗)
- 实现快速可靠将数据同步至Redis(同步数据到redis)
- 构建基于内存的Redis数据库(内存实现redis)
- 使用Redis实现远程删除数据(redis远程删除数据)
- 利用Redis轻松实现订单数据过期删除(redis过期删除订单)
- 从零开始简单快捷使用Redis设置地址(redis设置地址)
- Redis 节约存储空间的福音(redis节省存储空间)
- Redis连接异常无法连接到主机(redis连接不到主机)
- 使用Redis实现远程批量删除的方法(redis远程批量删除)
- Redis远程批量删除极速简便(redis远程批量删除)