当前位置: 首页 > news >正文

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是配合使用的,充分发挥两种持久化方式的优势,提高数据可靠性和恢复能力。

http://www.lryc.cn/news/297153.html

相关文章:

  • Oracle Vagrant Box 扩展根文件系统
  • TDengine用户权限管理
  • 推荐一款开源的跨平台划词翻译和OCR翻译软件:Pot
  • spring boot学习第十一篇:发邮件
  • Linux中ps/kill/execl的使用
  • 【web前端开发】HTML及CSS简单页面布局练习
  • 2.7日学习打卡----初学RabbitMQ(二)
  • 【工作学习 day04】 9. uniapp 页面和组件的生命周期
  • Mysql-数据库优化-客户端连接参数
  • 【十二】【C++】vector用法的探究
  • Docker 基本介绍
  • CentOS 7 安装 install abiword
  • 开源的直播平台
  • ChatGPT 变懒最新解释!或和系统Prompt太长有关
  • 书生·浦语大模型第三课作业
  • 【Redis笔记】分布式锁及4种常见实现方法
  • SpringMVC第一天
  • 如何利用腾讯工蜂提升广告推广和用户运营效率
  • 【QT+QGIS跨平台编译】之三十二:【MiniZip+Qt跨平台编译】(一套代码、一套框架,跨平台编译)
  • OLAP技术的发展及趋势简述
  • stupid_brain
  • C# BackgroundWorker的使用
  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • wyh的迷宫
  • AWS云用户创建
  • 微信小程序(三十七)选项点击高亮效果
  • 通过Demo学WPF—数据绑定(二)
  • 数据湖的整体思路
  • 51单片机 跑马灯
  • 迎新年年终总结