【Redis面试点总结】

news2025/1/12 23:09:13

1、缓存

1.1、穿透

查询一个空数据,mysql也查不到也不会写入缓存可能导致多次请求数据库

方案一:缓存设空即可(可能发生数据不一致就是这条数据有了但此时缓存是空,消耗内存)

方案二:布隆过滤器(实现复杂,容易产生误判)
在这里插入图片描述

在这里插入图片描述

1.2、击穿

一个key缓存过期重建过程中来了大量请求,缓存无数据全来到了数据库

方案一:互斥锁(强一致、性能差、一个线程进来其他线程都得等待)

在这里插入图片描述

方案二:逻辑过期(高可用、性能优、不能保证数据一致性)

在这里插入图片描述

添加逻辑过期expire字段:

在这里插入图片描述

1.3、雪崩

同一时段大量key失效或redis宕机,导致大量请求来到数据库

方案一:给不同的key的TTL添加随机值

方案二:利用redis集群提高可用性(哨兵模式、集群模式)

方案三:缓存业务添加降级限流策略(nginx、gateway)

方案四:给添加多级缓存(Guava或Caffeine)

1.4、双写一致(mysql数据与redis同步)

当修改了数据库的数据,同时也要更新缓存的数据,缓存要与数据库数据保持一致

读操作:缓存命中直接返回、未命中查询数据库写入缓存设置超时时间

写操作:延时双删(删除缓存–>修改数据库–>删除缓存)(双删防止脏数据、延时为了让主从模式把数据同步到从节点,延时过程中可能出现脏数据不能保证强一致性)

分布式锁(强一致性):

  1. 共享锁:读锁readLock,加锁过后其他线程共享读操作

在这里插入图片描述

  1. 排他锁:独占锁writeLock,加锁过后阻塞其他线程读写操作,底层setnx保证同一时刻只能一个线程操作锁住的方法

在这里插入图片描述

1.5、持久化

1.5.1、RDB

Redis Database Backup file(redis数据备份文件、数据快照)把内存所有数据存到磁盘,当redis故障重启后从磁盘快速读取快照文件恢复数据:命令1、save2、bgsave(子进程),redis.config也可设置自动备份策略(bgsave)

在这里插入图片描述

1.5.2、AOF

Append Only File(追加文件)redis处理的每一个写命令都会记录在AOF文件,可以看作命令日志文件,AOF默认关闭,在redis.config配置文件把appendonly的值改为yes也可修改AOF文件的名称

在这里插入图片描述

由于AOF是记录命令,文件要比RDB大得多。且AOF会记录同一个key的多次写操作,但实际上只有最后一次才有意义。通过bgrewriteaof命令重写。也可在配置文件设置重写阈值。

对比:

在这里插入图片描述

1.6、数据过期策略

  1. 惰性删除:该key过期后不管它,当需要该key后检查是否过期,若过期就删掉,反之返回该key(对cpu友好,对内存不友好存在大量用不到的key一直占内存)
  2. 定期删除:每隔一段时间检查一定量的key,删除其中过期的key(SLOW、FAST)

==》redis默认两种策略配合使用

1.7、淘汰策略

当redis的内存不够用,此时再添加key那么redis会按照某一逻辑将内存中的数据删除掉

在这里插入图片描述

面试:数据库1000万数据,redis只能存20万,如何保证redis的数据都是热点数据?(LRU)

2、集群

2.1、主从

  1. 主从全量同步:

在这里插入图片描述

在这里插入图片描述

  1. 主从增量同步:

在这里插入图片描述

2.2、哨兵

实现主从集群的自动故障修复(监控、恢复、通知)

1秒一个ping,哨兵选主(slave-priority越小优先级越高,offset越大,优先级越高)

脑裂:由于网络波动,发现ping不了master,之后选了个slave作为master,这就出现了两个master,但client还是向老master写数据,老master网络恢复后,无新增数据的新master把自个数据同步到老master,那么就丢失了此段时间的数据。更改配置文件解决:

在这里插入图片描述

2.3、分片集群

多个master集群,每个master数据不同,一个master有多个slave,master之间通过ping相互心跳检测

解决海量数据存储问题、高并发写的问题

redis分片引入了哈希槽的概念,redis集群有16384个哈希槽,每个key通过 CRC16 hash校验后对16384取模来决定放置在那个槽,集群每个节点负责一部分hash槽

在这里插入图片描述

3、分布式锁

本地锁只对本地起作用,因为jvm限制

3.1、setnx

添加锁:SET lock value NX EX 10(过期时间防止死锁业务超时或服务宕机会自动释放锁)

释放锁:DEL key

控制锁时长:1.根据业务执行时间预估(不推荐)2.给锁续期(redisson)

3.2、redisson

执行流程,新特性重试机制高并发下增加分布式锁的使用性能

在这里插入图片描述

基于Lua脚本保证命令执行原子性

在这里插入图片描述

可重入:跟据线程id判断,add1与add2属于同一线程所以add2会获取到锁

在这里插入图片描述

利用hash结构记录线程id和重入次数

在这里插入图片描述

主从一致性:当获取锁业务没结束后突然redis主节点(写、改、删数据)宕机,数据没来得及同步到子节点(读数据),那么集群默认选出一个子节点当作主节点替换掉宕机的,当另一个请求获取锁也是能够获取成功的这样两个线程公用一把锁就丧失了锁的互斥性,可能出现脏数据,方案:RedLock(红锁)(复杂、性能差)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/545243.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

hive数据库hql基础操作02

1.内部表和外部表 默认情况下创建的表就是内部表,Hive拥有该表的结构和文件。换句话说,Hive完全管理表(元数据和数据)的生命周期,类似于RDBMS中的表。当你删除内部表时,它会删除数据以及表的元数据。可以使…

【python】价值25~30K的国外企业招聘面试考题

目录标题 前言案例介绍网站分析代码展示尾语 💝 前言 嗨喽~大家好呀,这里是魔王呐 ❤ ~! 今天的这个案例,是一位同学的面试题,人在国外,月薪25~30K 本来以为是难度很大的反pa、逆向或者算法之类的, 谁知道…

深度学习笔记1——CNN识别黑白手写数字

文章目录 摘要手写数字数据集(MNIST)卷积神经网络(Convolution Neural Network, CNN)模型架构搭建Softmax函数和CrossEntropy损失函数Adam 优化器 构造数据迭代器训练、验证、测试模型训练结果可视化 摘要 本文将介绍CNN的开山之…

读书笔记--读数学之美有感

大概是在10年前,无意间读到吴军老师撰写得数学之美,感觉吴老师对数学与信息论的结合讲述的太好了,吴老师结合自身的多年工作经历将信息技术中用到的数学,特别是数学里面的很多概率论、线性代数、模型算法、编解码规则等&#xff0…

gunicorn常用参数命令

Gunicorn 是一个 Python 的 WSGI HTTP 服务器。具有实现简单,轻量级,高性能等特点。更多介绍内容参考官网,这里介绍几个常用参数。 安装 pip3 install gunicorn通过输入gunicorn -v查看版本。 最简洁的启动。首先进入到项目目录,例如django项目和mana…

Vue中通过集成Quill富文本编辑器实现公告的发布。Vue项目中vue-quill-editor的安装与使用【实战开发应用】

前言 闲的无聊、给原有的系统添加一个公告的功能。就是后台可以写一些公告信息,然后前台可以看到发布的信息。一般来说一个公告就是一些文字描述图片视频等。还有排版样式啥的。使用文本编辑器就可以实现。然后正好用到了Quill,通过Quill富文本编辑器集成…

JS逆向 -- 某视频vurl值的加密分析

接上节课内容 JS逆向 -- 某视频vid值的加密分析 JS逆向 -- 某视频val值和pid值的加密分析 一、在上节课中有个vurl的值需要分析,具体内容如下 vurl: https://mp4play-hs-cdn.ysp.cctv.cn/o000017kuww.jbZe10002.mp4? sdtfrom4330701& guidlhsuf6ia_0rieucp…

进程性能分析工具 pidstat 和用 python 的 matplotlib 库输出分析图表

文章目录 前情提要效果展示pidstat 简介matplotlib 简介认识 figure 和 axes绘制曲线图绘制柱形图创建两个轴,将上面两种图形放到一个 figure 中Backends of matplotlib如何使用 WebAgg注意事项 前情提要 这段时间在忙服务器压测的工作,虽然我们程序里面…

五种高效的原型设计工具推荐

软件产品的诞生注定要经历一个过程:需求分析、设计、开发、测试和在线。在设计阶段,原型设计是软件设计和开发的重要保证。与其他工作一样,高效的原型设计需要相应工具的帮助来完成原型设计。在许多原型设计工具中,这里推荐了五种…

洛谷P1420-最长连号

洛谷P1420-最长连号 这个题目很入门,但是我第一次做怎么做都做不出来,看了几个代码,方法各式各样,这个我是我觉得最通俗易懂的一个, 循环外面的两个输入第一个cin是个数第二个是输入的第一个数,所以下面for循环的条件…

毕业论文之转化为三线表格(wps)

目录 一、前言 1.修改之前的表格 2. 修改完成后(三线表格式) 二、操作步骤 一、前言 在论文里面的表格要求是三线表格式的时候,就需要我们去把这个表格修改成三线表格式。 1.修改之前的表格 2. 修改完成后(三线表格式&…

Vulnhub靶机渗透:Raven1(超级详细)

Raven1 https://www.vulnhub.com/entry/raven-1,256/ kali:192.168.54.128 raven1:192.168.54.15 nmap扫描 端口扫描 # Nmap 7.93 scan initiated Thu May 18 16:41:33 2023 as: nmap --min-rate 20000 -p- -oN nmap/ports 192.168.54.15 Nmap scan report for 192.168.54.…

PPT / Powerpoint中利用LaTeX输入公式

新版的Word(Office 2016后?)是支持LaTeX公式输入的,但是Powerpoint并不支持。下面介绍如何利用latex-ppt插件实现PPT中输入LaTeX公式: 1 安装latex-ppt插件 1.1 下载插件 插件开源仓库:latex-ppt&#x…

Linux【Ubuntu】安装Docker配置docker-compose 编排工具

一:Docker具体安装传送门: 亲测有效 https://www.runoob.com/docker/ubuntu-docker-install.html 二:配置Docker编排工具docker-compose 1,下载Docker-compose 下载Docker-Compose(下载完毕就是一个文件docker-compose-Linux-x…

实验10 超市订单管理系统综合实验

实验10 超市订单管理系统综合实验 应粉丝要求,本博主帮助实现基本效果! 未避免产生版权问题,本项目博主不公开源码,如果您遇到相关问题可私聊博主! 一、实验目的及任务 通过该实验,掌握利用SSM框架进行系…

生成式AI热潮:一场“添饭碗”的科技革命

今年以来,人工智能(AI)热潮席卷全球,被认为将掀起新的科技革命。 5月18日的2023天津世界智能大会,以“智行天下 能动未来”为主题,重点关注人工智能发展的新趋势、新技术、新业态。大会开幕式结束之后&…

lidar camera calibration

1 Automatic Extrinsic Calibration Method for LiDAR and Camera Sensor Setups 2022 vel2cam git 2 A Novel Method for LiDARCamera Calibration by PlaneFitting 本文介绍了一种使用带ArUco标记的立方体的3D-3D对应特征来校准LiDAR和相机的新方法。在LiDAR坐标系中&…

安全响应中心 — 垃圾邮件事件报告(5.16)

2023年5月 第二周 一. 样本概况 ✅ 类型1:二维码钓鱼(QRPhish) 利用二维码进行的钓鱼、投毒,成为目前常见的邮件攻击手段之一,该类二维码主要存在于网络链接图片、邮件内容图片、附件图片中。 近日,安全团队捕获到一类基于员工…

什么是DevOps?如何理解DevOps思想?

博文参考总结自:https://www.kuangstudy.com/course/play/1573900157572333569 仅供学习使用,若侵权,请联系我删除! 1、什么是DevOps? DevOps是一种思想或方法论,它涵盖开发、测试、运维的整个过程。DevOps强调软件开…

三阶段项目相关内容

当虚拟网关和真实物理网关相同的时候,默认优先级是255 vrrp角色: 主路由器 备份路由器 虚拟路由器 计时器:发送hello报文的时间, 主网关:每隔1s会向备份发一次vrrp报文 备份网关:监听vrrp报文,主网…