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

相关文章:

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

redis的过期淘汰策略 redis过期淘汰策略有很多,默认是no-eviction 不删除任何数据,内存不足存入会直接报错,可以在redis配置文件中进行设置,其中有两个非常重要的概念,LRU与LFU LRU表示最近最少使用,LFU为最少频率使用 又按照volatile已设置过期时间的数据集和allkeys所有数…...

Oracle Vagrant Box 扩展根文件系统

需求 默认的Oracle Database 19c Vagrant Box的磁盘为34GB。 最近在做数据库升级实验,加之导入AWR dump数据,导致空间不够。 因此需要对磁盘进行扩容。 扩容方法1:预先扩容 此方法参考文档Vagrant, how to specify the disk size?。 指…...

TDengine用户权限管理

Background 官方文档关于用户管理没有很详细的介绍,只有零碎的几条,这里记录下方便后面使用。官方文档:https://docs.taosdata.com/taos-sql/show/#show-users 1、查看用户 show users;super 1,表示超级用户权限 0,表…...

推荐一款开源的跨平台划词翻译和OCR翻译软件:Pot

Pot简介 一款开源的跨平台划词翻译和OCR翻译软件 下载安装指南 根据你的机器型号下载对应版本,下载完成后双击安装即可。 使用教程 Pot具体功能如下: 划词翻译输入翻译外部调用鼠标选中需要翻译的文本,按下设置的划词翻译快捷键即可按下输…...

spring boot学习第十一篇:发邮件

1、pom.xml文件内容如下&#xff08;是我所有学习内容需要的&#xff0c;不再单独分出来&#xff0c;包不会冲突&#xff09;&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"…...

Linux中ps/kill/execl的使用

ps命令&#xff1a; ps -aus或者ps -ajx或者 ps -ef可以查看有哪些进程。加上 | grep "xxx" 可以查看名为”xxx"的进程。 ps -aus | grep "xxx" kill命令&#xff1a; kill -9 pid 杀死某个进程 kill -l 查看系统有哪些信号 execl函数&#…...

【web前端开发】HTML及CSS简单页面布局练习

案例一 网页课程 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-wi…...

2.7日学习打卡----初学RabbitMQ(二)

2.7日学习打卡 JMS 由于MQ产品很多&#xff0c;操作方式各有不同&#xff0c;于是JAVA提供了一套规则 ——JMS&#xff0c;用于操作消息中间件。JMS即Java消息服务 &#xff08;JavaMessage Service&#xff09;应用程序接口&#xff0c;是一个Java平台中关于面 向消息中间件的…...

【工作学习 day04】 9. uniapp 页面和组件的生命周期

问题描述 uniapp常用的有&#xff1a;页面和组件&#xff0c;并且页面和组件各自有各自的生命周期函数&#xff0c;那么在页面/组件请求数据时&#xff0c;是用created呢&#xff0c;还是用onLoad呢&#xff1f; 先说结论: 组件使用组件的生命周期&#xff0c;页面使用页面的…...

Mysql-数据库优化-客户端连接参数

客户端参数 原文地址 # 连接池配置 # 初始化连接数 spring.datasource.druid.initial-size1 # 最小空闲连接数&#xff0c;一般设置和initial-size一致 spring.datasource.druid.min-idle1 # 最大活动连接数&#xff0c;一个数据库能够支撑最大的连接数是多少呢&#xff1f; …...

【十二】【C++】vector用法的探究

vector类创建对象 /*vector类创建对象*/ #if 1 #define _CRT_SECURE_NO_WARNINGS#include <iostream> using namespace std; #include <vector> #include <algorithm> #include <crtdbg.h>class Date {public:Date(int year 1900, int month 1, int …...

Docker 基本介绍

Docker 基本介绍 镜像 Docker镜像就是一个只读的模板。 例如&#xff1a;一个镜像可以包含一个完整的ubuntu操作系统环境&#xff0c;里面仅安装了Apache或用户需要的其它应用 程序。 镜像可以用来创建Docker容器。Docker提供了一个很简单的机制来创建镜像或者更新现有的镜…...

CentOS 7 安装 install abiword

安装 1.下载noarch安装包 wget http://repo.iotti.biz/CentOS/7/noarch/lux-release-7-1.noarch.rpm 2.安装noarch rpm -Uvh lux-release-7-1.noarch.rpm 3.安装abiword yum -y install abiword...

开源的直播平台

​​​​​​直播平台系统界面介绍 开源一套直播平台 私信可获取源码...

ChatGPT 变懒最新解释!或和系统Prompt太长有关

大家好我是二狗。 ChatGPT变懒这件事又有了最新解释了。 这两天&#xff0c;推特用户Dylan Patel发文表示&#xff1a; 你想知道为什么 ChatGPT 和 6 个月前相比会如此糟糕吗&#xff1f; 那是因为ChatGPT系统Prompt是竟然包含1700 tokens&#xff0c;看看这个prompt里面有多…...

书生·浦语大模型第三课作业

基础作业&#xff1a; 复现课程知识库助手搭建过程 (截图) 进阶作业&#xff1a; 选择一个垂直领域&#xff0c;收集该领域的专业资料构建专业知识库&#xff0c;并搭建专业问答助手&#xff0c;并在 OpenXLab 上成功部署&#xff08;截图&#xff0c;并提供应用地址&#x…...

【Redis笔记】分布式锁及4种常见实现方法

线程锁 主要用来给方法、代码块加锁。当某个方法或代码使用锁&#xff0c;在同一时刻仅有一个线程执行该方法或该代码段。线程锁只在同一JVM中有效果&#xff0c;因为线程锁的实现在根本上是依靠线程之间共享内存实现的&#xff0c;比如Synchronized、Lock等。 进程锁 控制同…...

SpringMVC第一天

一、SpringMVC简介 1 SpringMVC概述 1.1 SpringMVC概述 SpringMVC是一种基于Java实现MVC模型的轻量级Web框架 优点 使用简单&#xff0c;开发便捷&#xff08;相比于Servlet&#xff09; 灵活性强 2 入门案例【重点】 问题导入 在Controller中如何定义访问路径&#xff…...

如何利用腾讯工蜂提升广告推广和用户运营效率

无代码开发&#xff1a;腾讯工蜂的连接优势 在广告推广和用户运营中&#xff0c;腾讯工蜂的无代码开发优势让广告系统和用户运营系统能够轻松地实现无需API开发的集成。这使得没有专业编程技能的工作人员也能通过腾讯工蜂的用户友好界面&#xff0c;实现系统的快速连接和集成&…...

【QT+QGIS跨平台编译】之三十二:【MiniZip+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

文章目录 一、MiniZip介绍二、文件下载三、文件分析四、pro文件五、编译实践一、MiniZip介绍 MiniZip是一个轻量级的开源库,用于创建、读取和操作ZIP文件格式的压缩文件。它提供了一组简单而灵活的API,可以方便地在应用程序中进行ZIP文件的压缩和解压操作。 MiniZip的主要特…...

当代酷刑:如厕等信号

如厕等信号&#xff0c;属于当代十大酷刑之一。作为社会观察理性分析的结合体&#xff0c;今天&#xff0c;我想写一些这物理世界的墙&#xff0c;也是这消费世界的墙。你有没有过这样的感受&#xff1f;不管你家里换了多么厉害的宽带&#xff0c;多么高端前沿的路由器&#xf…...

3步终极指南:彻底解决Cursor Pro试用限制的技术实现方案

3步终极指南&#xff1a;彻底解决Cursor Pro试用限制的技术实现方案 【免费下载链接】cursor-free-vip [Support 0.45]&#xff08;Multi Language 多语言&#xff09;自动注册 Cursor Ai &#xff0c;自动重置机器ID &#xff0c; 免费升级使用Pro 功能: Youve reached your t…...

OpenClaw 把 Context 管理抽象成了可插拔的 Context Engine,为什么要做这层抽象?这个设计能支持哪些不同的策略?

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:AI大模型原理和应用面试题 文章目录 一、🍀回答重点 二、🍀扩展知识 2.1 ☘️内置的 legacy 引擎 2.2 ☘️可以实现的高级策略 2.3 ☘️插件注册机制 …...

数据投资回报率金字塔:衡量和最大化数据团队价值的方法

原文&#xff1a;towardsdatascience.com/the-data-roi-pyramid-a-method-for-measuring-maximizing-your-data-team-cab470b98cf6?sourcecollection_archive---------4-----------------------#2024-02-02 难以清晰表达你数据团队的价值&#xff1f;了解如何使用数据投资回报…...

Docusaurus技能库插件:打造动态技术栈展示面板

1. 项目概述&#xff1a;一个为Docusaurus注入灵魂的技能库插件如果你正在使用Docusaurus构建技术文档、博客或知识库&#xff0c;并且希望站点不仅仅是静态内容的堆砌&#xff0c;而是能动态展示你或你团队的技术栈、技能熟练度&#xff0c;那么rio225/docusaurus-skill这个项…...

从create-codex项目看AI代码生成工具的工程化集成实践

1. 项目概述&#xff1a;从“create-codex”看AI代码生成工具的深度集成最近在GitHub上看到一个挺有意思的项目&#xff0c;叫ramonclaudio/create-codex。光看这个名字&#xff0c;很多开发者可能就会心一笑——“create”前缀加上“codex”&#xff0c;这不就是围绕OpenAI的C…...

抖音下载神器:如何一键批量保存无水印视频和音乐?

抖音下载神器&#xff1a;如何一键批量保存无水印视频和音乐&#xff1f; 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallbac…...

构建个人数字档案馆:用静态站点生成器永久保存思想印记

1. 项目概述&#xff1a;一个灵魂的数字化栖息地 最近在整理个人数字资产时&#xff0c;我常常感到一种无力感。十几年来&#xff0c;从博客、社交媒体到各种笔记应用&#xff0c;产生的文字、图片、链接散落在各处&#xff0c;像一座座孤岛。有些平台已经关闭&#xff0c;有些…...

芯片良率提升:从设计到制造的系统性工程实践

1. 项目概述&#xff1a;从“能用”到“好用”的生死线“芯片良率”这四个字&#xff0c;对于圈外人来说&#xff0c;可能只是个模糊的技术指标。但对于身处半导体行业&#xff0c;无论是设计、制造、封测还是终端应用环节的从业者而言&#xff0c;它是一条贯穿始终、关乎生死存…...

SAP S4后台表PRCD_ELEMENTS增量同步逻辑

PRCD_ELEMENTS本身没有创建或修改的时间戳&#xff0c;可采用下面的方式做增量同步&#xff1a; 1.SD模块有3个点分别增量同步 1&#xff09;销售订单&#xff1a;通过VBAK-KNUMV关联PRCD_ELEMENTS-KNUMV&#xff0c;且PRCD_ELEMENTS-KAPPL V&#xff0c;按VBAK-ERDAT(新增)…...