本文目录一览:
- 1、redis使用哪种持久化策略好
- 2、Redis缓存淘汰策略
- 3、Redis过期删除策略和内存淘汰策略
- 4、Redis过期后,是用什么淘汰策略?
RDB持久化机制,对redis中的 数据 执行周期性的持久化 。AOF机制对 每条写入命令 作为日志,以append-only的模式写入一个日志文件 , 在redis重启对时候,可以通过回放AOF日志中写入的指令来重新构建整个的数据集 。
redis提供两种方式进行持久化,一种是RDB持久化(原理是将Reids在内存中的数据库记录定时dump到磁盘上的RDB持久化),另外一种是AOF(append only file)持久化(原理是将Reids的操作日志以追加的方式写入文件) 。
没有满足第二种条件时,在300秒内有10次操作即触发RDB持久化 。RDB持久化除了可以根据配置中的策略来触发外 , 还可以使用save和bgsave命令手动来触发 。这两个命令的区别在于save会阻塞服务器进程 。
而AOF持久化是以日志的形式记录在服务器所处理的每一个写、删操作,查询操作不会被记录,以文本的方式记录,可以打开文件看到详细的操作记录 。
Redis 的持久化有两种策略:RDB(Redis Database):指定的时间间隔能对你的数据进行快照存储 。AOF(Append Only File):每一个收到的写命令都通过write函数追加到文件中 。
Redis缓存淘汰策略1、定期删除策略:Redis 启用一个定时器定时监视所有的 key,判断key是否过期 , 过期的话就删除 。
2、值得一提的是,设置expire会消耗额外的内存,所以 使用allkey-lru可以更高效地使用内存,因为这样使用的时候不需要设置过期时间 。Redis使用的并不是完全LRU算法,而是近似LRU算法 。
3、noeviction:默认策略,不淘汰数据;大部分写命令都将返回错误(DEL等少数除外) 。allkeys-lru:从所有数据中根据 LRU 算法挑选数据淘汰 。volatile-lru:从设置了过期时间的数据中根据 LRU 算法挑选数据淘汰。
4、Redis 内存淘汰机制有以下几个:noeviction: 当内存不足以容纳新写入数据时,新写入操作会报错 , 这个一般没人用吧,实在是太恶心了 。
5、redis根据maxmemory-samples随机抽取一部分数据,将最旧的数据淘汰,指到内存降下来 。
6、springboot整合Redis参考 , SpringBoot整合Redis - (jianshu.com) 在整合Redis的基础上,在新加监听配置 监听配置类 监听类 将Redis用作缓存时 , 如果内存空间用满 , 就会自动驱逐老的数据 。
Redis过期删除策略和内存淘汰策略redis根据maxmemory-samples随机抽取一部分数据,将最旧的数据淘汰 , 指到内存降下来 。
(被动)惰性删除:当客户端请求到一个已经过期的key时,redis会检查是否过期并删除 所以,虽然key过期了,但是没被清理的话 , 还是会占内存的 。
每次淘汰时会将随机出来的key和数组里的key融合,淘汰掉最旧的一个,然后将剩下的较旧的key放到淘汰池里给下个循环用 。redis的删除del在删除一个大对象的时候有可能造成卡顿 。
redis 过期策略是: 定期删除+惰性删除。所谓定期删除,指的是 redis 默认是每隔 100ms 就随机抽取一些设置了过期时间的 key,检查其是否过期,如果过期就删除 。
值得一提的是,设置expire会消耗额外的内存,所以 使用allkey-lru可以更高效地使用内存,因为这样使用的时候不需要设置过期时间 。Redis使用的并不是完全LRU算法,而是近似LRU算法 。
定期删除在一定程度上是一种合理有效的过期键删除策略,但是由于其在执行时长和执行频度的局限性,必须要有另一种机制(策略)确保内存能够获得回收,因此,就需要引入内存淘汰策略 。
Redis过期后,是用什么淘汰策略?1、Redis 中数据过期策略采用定期删除+惰性删除策略 。定期删除策略:Redis 启用一个定时器定时监视所有的 key,判断key是否过期,过期的话就删除 。
2、noeviction:默认策略,不淘汰数据;大部分写命令都将返回错误(DEL等少数除外) 。allkeys-lru:从所有数据中根据 LRU 算法挑选数据淘汰 。volatile-lru:从设置了过期时间的数据中根据 LRU 算法挑选数据淘汰。
3、那对于过期数据,一般有三种方式进行处理:Redis的过期删除策略: 惰性删除 和 定期删除 两种策略配合使用 。spring-boot-starter-data-redis 包中提供了监听过期的类,对于key过期,需要得到通知,做业务处理的 , 可以做此监听 。
4、内存淘汰管理机制Memory Management 当内存占满之后,redis提供缓存淘汰机制 。
【redis 回收策略 redis回收策略选哪个】5、为了解决上面的问题,Redis引入了LFU算法,淘汰最少使用的数据 。原理如下: LFU给每个数据维护了一个计数器,每次使用都会使计数器增加,淘汰使用次数最少的键 。
推荐阅读
- redisclient命令 redis命令窗口
- redis主从哨兵模式搭建 redis主从和哨兵
- redis删除缓存和更新缓存的区别 redis删除缓存和更新缓存
- 大数据需要学spring吗 大数据专业需不需要学redis
- redis查看key值 redis如何知道key的类型
- redis几种数据类型的使用场景 redis数据类型存储原理