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

Redis2

为什么Redis要给缓存数据设置过期时间?

内存是有限的,如果缓存中的所有数据都是一直保存,很容易OOM

Redis如何判断数据是否过期?

通过过期字典来保存数据的过期时间

过期删除策略

Redis采用的是定期删除+惰性删除

Redis内存淘汰机制

1. noeviction(默认):不淘汰任何key,内存满时不写入新的key。
2. volatile-ttl:对设置了TTL的key,比较key的剩余TTL值,值越小越先被淘汰
3. allkeys-random:对所有key进行随机淘汰
4. volatile-random:对设置了TTL的key进行随机淘汰
5. allkeys-lru:对所有key基于LRU算法进行淘汰
6. volatile-lru:对设置了TTL的key基于LRU算法进行淘汰
7. allkeys-lfu:对全体key给予LFRU算法进行淘汰
8. volatile-lfu:对设置了TTL的key基于LFU算法进行淘汰

怎么保证Redis挂掉之后重启数据可以进行恢复?

依赖持久化机制

什么是RDB持久化?

实现类似照片记录效果的方式,就是把某一时刻的数据和状态以文件的形式写到磁盘上,也就是快照。这样一来即使故障宕机,快照文件也不会丢失,数据的可靠性也就得到了保证。这个快照文件就称为RDB文件(dump.rdb)

什么是AOF持久化?

以日志的形式来记录每个写操作,将Redis执行过的所有写命令记录下来,只许追加文件但不可以改写文件,redis启动之初会读取该文件重新构建数据。

Redis4.0对于持久化机制做了什么优化?

支持开启混合方式设置 设置aof-use-rdb-preamble的值为 yes 表示开启,设置为no表示禁用

RDB+AOF的混合方式---------> 结论:RDB镜像做全量持久化,AOF做增量持久化

先使用RDB进行快照存储,然后使用AOF持久化记录所有的写操作,当重写策略满足或手动触发重写的时候,将最新的数据存储为新的RDB记录。这样的话,重启服务的时候会从RDB和AOF两部分恢复数据,既保证了数据完整性,又提高了恢复数据的性能。简单来说:混合持久化方式产生的文件一部分是RDB格式,一部分是AOF格式。

如何使用Redis事务?

Redis通过MULTI、EXEC、DISCARD、WATCH等命令来实现事务。

Redis事务支持原子性吗?

Redis的事务不保证原子性,也就是不保证所有指令同时成功或同时失败,只有决定是否开始执行全部指令的能力,没有执行到一半进行回滚的能力

什么是bigkey?有什么危害?

对于string类型的value,大于等于 10kb 就是bigkey

对于list、hash、set、zset类型,超过5000个属于bigkey

危害:

1.内存不均

2.超时删除

3.网络流量阻塞

如何发现bigkey?

使用--bigkeys参数查找或者分析RDB文件

如何避免大量key集中过期?

1.给key设置随机过期时间

2.开启lazy-free惰性删除

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

相关文章:

  • C语言--函数
  • Shell 编程的高级技巧和实战应用
  • VMWare虚拟机如何连接U盘
  • 【学习笔记】后缀自动机(SAM)
  • Godot的节点与场景
  • C++ 学习(2) ---- std::cout 格式化输出
  • 前端拿不到Long类型成员变量,用@JsonSerialize(using = ToStringSerializer.class)序列化一下
  • JWT登录校验流程
  • yarn安装和部署
  • Visual Studio的安装教程与使用方法
  • 一键换装软件哪个好?6个换装工具让你秒变穿搭达人
  • 【EtherCAT】Windows+Visual Studio配置SOEM主站——源码配置
  • GPTPDF深度解析:开源文档处理技术全攻略
  • 网络学习:应用层DNS域名解析协议
  • 7.怎么配置一个axios来拦截前后端请求
  • Day17_1--AJAX学习之GET/POST传参
  • golang国内proxy设置
  • 全网最适合入门的面向对象编程教程:31 Python的内置数据类型-对象Object和类型Type
  • 【mongodb】mongodb副本集的搭建和使用
  • Java后端面试复习7.24
  • 前端 HTML 概述
  • 探索Thymeleaf:用动态Web模板引擎打造吸引人的用户界面(SpringBoot的html详解)
  • 视频教程 - 自研Vue3 Tree组件高级功能:虚拟滚动新增节点实现自动滚动
  • 职业生涯阶段总结3:转眼毕业三年
  • 项目经理面试总结
  • (免费领源码)java#springboot#mysql大学校园旧物捐赠网站 25109-计算机毕业设计项目选题推荐
  • Java 设计模式之单例模式
  • Linux系统驱动(二)字符设备驱动
  • Day29 | 动态规划 509. 斐波那契数 70. 爬楼梯 746. 使用最小花费爬楼梯
  • 【开源移植】MultiButton_小型按键驱动模块移植