redis过期淘汰策略、数据过期策略与持久化方式

redis的过期淘汰策略

redis过期淘汰策略有很多,默认是no-eviction 不删除任何数据,内存不足存入会直接报错,可以在redis配置文件中进行设置,其中有两个非常重要的概念,LRU与LFU

LRU表示最近最少使用,LFU为最少频率使用

又按照volatile已设置过期时间的数据集和allkeys所有数据集,官方提供的淘汰策略有八种

no-eviction禁止驱逐数据、vilatile-lru已设置过期时间数据集选择最近最少使用数据淘汰、volatile-ttl已设置过期时间数据集选择将要过期数据淘汰、volatile-random已设置过期时间数据集中任意选择数据淘汰、volatile-lfu已设置过期时间数据集选择最不经常使用数据淘汰、allkeys-lru所有数据集最近最少使用数据淘汰、allkeys-random所有数据集任意数据淘汰、allkeys-lfu所有数据集中最不经常使用数据淘汰

redis数据过期策略

redis提供两种数据过期删除策略,惰性删除与定期删除

惰性删除:设置key过期时间后,不去管他,需要数据键值对的时候对key进行过期检查,如果过期,删除数据,反之返回该key

定期删除:每隔一段时间,对key进行检查,删除过期的key

定期删除有两种模式:

slow模式是定时任务,执行频率默认10hz,每次不超过25ms,可通过修改配置文件redis.conf的hz选项来调整这个数

fast模式执行频率不固定,每次事件循环都会尝试执行,两次间隔不低于2ms,每次耗时不超过1ms

两者相比,定期删除对内存更加友好,惰性删除对cpu更加友好

一般是惰性删除和定期删除两种策略配合使用

redis数据持久化方式

所谓的redis持久化就是将redis内存中的数据备份到磁盘上,官方提供两种持久化方式RDB和AOF

RDB就是将快照二进制文件备份到磁盘上,存储的是数据本身

AOF是追加文件,将redis执行过的所有写指令备份到磁盘上,redis实例宕机回复数据的时候,会从文件中在执行一遍指令来回复数据

RDB存储的是二进制文件,保存时候存储体积较小,回复速度较快,但会丢失数据,可定期进行RDB快照备份,需要的时候进行全量数据回复。AOF相比而言数据文件较大、回复速度较慢,丢失数据风险小。可将AOF的刷盘策略appendfsync参数设置为每秒进行刷盘everysec,保证redis每秒将AOF缓冲区的写惭怍同步到AOF文件中,提高数据持久化能力

一般RDB与AOF是配合使用的,充分发挥两种持久化方式的优势,提高数据可靠性和恢复能力。

相关推荐
煎饼小狗34 分钟前
Redis五大基本类型——Zset有序集合命令详解(命令用法详解+思维导图详解)
数据库·redis·缓存
秋意钟2 小时前
缓存雪崩、缓存穿透【Redis】
redis
简 洁 冬冬3 小时前
046 购物车
redis·购物车
soulteary3 小时前
突破内存限制:Mac Mini M2 服务器化实践指南
运维·服务器·redis·macos·arm·pika
wkj0014 小时前
php操作redis
开发语言·redis·php
菠萝咕噜肉i5 小时前
超详细:Redis分布式锁
数据库·redis·分布式·缓存·分布式锁
登云时刻6 小时前
Kubernetes集群外连接redis集群和使用redis-shake工具迁移数据(二)
redis·容器·kubernetes
Dlwyz9 小时前
redis-击穿、穿透、雪崩
数据库·redis·缓存
工业甲酰苯胺11 小时前
Redis性能优化的18招
数据库·redis·性能优化
Oak Zhang14 小时前
sharding-jdbc自定义分片算法,表对应关系存储在mysql中,缓存到redis或者本地
redis·mysql·缓存