java面试题(redis)
目录
1.redis主要消耗什么物理资源?
2.单线程为什么快
3.为什么要使用Redis
4.简述redis事务实现
5.redis缓存读写策略
6.redis除了做缓存,还能做些什么?
7.redis主从复制的原理
8.Redis有哪些数据结构?分别有哪些典型的应用场景?
9.如何解决 Redis 的并发竞争 Key 问题
10.缓存雪崩、缓存穿透、缓存击穿,如何解决
11.Redis和Mysql如何保证数据一致
12.redis的持久化机制
13.redis内存淘汰机制
14.Redis如何设置key的过期时间
15.Redis过期键的删除机制
16.Redis集群会有写操作丢失吗?为什么?
17.redis集群方案
18.Redis常见性能问题和解决方案?
19.Redis分布式锁是如何实现的?
20.Redis死锁情况,如何避免死锁
21.redis 6.0新增特性
22.redis 6.0为什么要改为多线程
23.redis和redisson有什么关系?
1.redis主要消耗什么物理资源?
内存
2.单线程为什么快
1.纯内存操作
2.核心是基于非阻塞的IO多路复用机制,避免了多线程的频繁上下文切换带来的性能问题
3.Redis 内置了多种优化过后的数据结构实现,性能非常高
3.为什么要使用Redis
高性能:操作缓存就是直接操作内存,所以速度相当快
高并发:Redis每秒查询次数最高能达到 30w+,能够承受的请求数量是远远大于直接访问数据库的
4.简述redis事务实现
事务是一个单独的隔离操作:一组按顺序执行的命令集合;事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行
实现:
1.执行命令 multi 开启一个事务
2.开启事务之后执行的命令都会被放入一个队列,如果成功之后会固定返回队列
3.执行命令 exec 提交事务之后,Redis 会依次执行队列里面的命令,并依次返回所有命令结果(如果想要放弃事务,可以执行 discard 命令)
命令:
multi:开启事务
exec:执行事务
discard:取消事务
watch:监视
5.redis缓存读写策略
旁路缓存模式:服务端同时维护Mysql和Redis,并且以Mysql的主要存储;
读:先从Redis中读,如果Redis中没有,再从Mysql中读取,并将结果返回写入Redis
写:先写Mysql,再删除Redis
缺陷:1.首次请求数据一定不在 Redis中(可以将热点数据可以提前放入Redis中)2.写操作比较频繁的话导致 cache 中的数据会被频繁被删除,这样会影响缓存命中率(加一个锁)
读写穿透:视Redis为主要存储
读:先从Redis中读,读到直接返回。没有读到就从Mysql中读取数据放入到Redis中后,再返回数据
写:先看Redis中是否存在该数据,存在则先更新换,再更新数据库
缺陷:1.首次请求数据一定不在 Redis中(可以将热点数据可以提前放入Redis中)
异步缓存写入:视Redis为主要存储
只更新缓存,不直接更新Mysql,而是改为异步批量的方式来更新Mysql
6.redis除了做缓存,还能做些什么?
分布式锁
限流:一般是通过 Redis + Lua 脚本的方式来实现限流
消息队列 ........
7.redis主从复制的原理
数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器;
好处:
- 数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式
- 负载均衡:可以轻易地实现横向扩展,实现读写分离
- 故障恢复:如果master宕掉了,使用哨兵模式,可以提升一个 slave 作为新的 master,进而实现故障转移,实现高可用
流程:
slave服务器连接到master服务器,便开始进行数据同步
master服务器收到psync命令之后,开始执行bgsave命令生成RDB快照文件并使用缓存区记录此后执行的所有写命令
master服务器bgsave执行完之后,就会向所有Slava服务器发送快照文件,并在发送期间继续在缓冲区内记录被执行的写命令。
slave服务器收到RDB快照文件后,会将接收到的数据写入磁盘,然后清空所有旧数据,在从本地磁盘载入收到的快照到内存中,同时基于旧的数据版本对外提供服务。
master服务器发送完RDB快照文件之后,便开始向slave服务器发送缓冲区中的写命令。
slave服务器完成对快照的载入,开始接受命令请求,并执行来自主服务器缓冲区的写命令;
如果slave node开启了AOF,那么会立即执行BGREWRITEAOF,重写AOF。
8.Redis有哪些数据结构?分别有哪些典型的应用场景?
String:字符串;计数器、分布式id、token
hash:哈希;用户信息、商品信息、文章信息、购物车信息
List:列表;最新文章、最新动态
Set:集合;共同关注、点赞
ZSet:有序集合;排行榜
9.如何解决 Redis 的并发竞争 Key 问题
Redis 的并发竞争 Key 的问题也就是多个系统同时对一个 key 进行操作
解决方案:
- 乐观锁:适用于大家一起抢着改同一个key,对修改顺序没有要求的场景,使用watch命令来实现
- 分布式锁:在业务层进行控制,操作 redis 之前,先去申请一个分布式锁,拿到锁的才能操作
- 时间戳:写入时保存一个时间戳,写入前先比较自己的时间戳是不是早于现有记录的时间戳,如果早于,就不写入
- 消息队列:在并发量很大的情况下,可以通过消息队列进行串行化处理
10.缓存雪崩、缓存穿透、缓存击穿,如何解决
缓存雪崩:缓存同一时间大面积失效,所有请求落在数据库上
解决:
缓存数据过期时间设置随机,防止同一时间大面积过期
给每个缓存增加标记,记录缓存是否失效,如果失效,则更新数缓存
缓存预热
互斥锁
缓存穿透:缓存和数据库中都没有数据,所有请求都落在数据库上
解决:
接口层增加校验,如用户鉴权校验,id做基础校验
从缓存取不到的数据,在数据库中也没有取到,可以将value设为null
布隆过滤器,将所有数据存到bitmap中,不存在数据会被拦截掉
缓存击穿:同一条数据,缓存中没有,数据库中有,但由于访问并发量大,造成数据库压力大
解决:
设置热点数据永远不过期
加互斥锁,互斥锁缓存预热
11.Redis和Mysql如何保证数据一致
延迟双删:先删除redis数据,再更新mysql,延迟几百毫秒,再删除redis数据;
12.redis的持久化机制
持久化机制:redis数据都是存储在内存中,为了避免数据丢失,需要将数据以某种形式从内存中保存到硬盘中,重启时利用持久化数据恢复。
RDB(快照):指定时间间隔将数据进行快照存储,重启时读取文件来恢复数据
触发方式:
- 配置文件
- 执行filshall命令(这个命令就相当于删库跑路)
- 执行shutdown命令(客户端执行命令)
- 执行bgsave命令(对save命令的优化,异步操作)
- 执行save命令(同步操作命令)
AOF(日志文件):记录每次对服务器的操作,当服务器重启重新执行这些命令恢复原始数据
aof持久化方式redis是默认不开启的,我们可以通过配置文件开启aof持久化方式(appendonly的值默认为no,改为yes)
13.redis内存淘汰机制
跟redis的内存淘汰机制有关,默认是当内存用完写入数据报错
内存淘汰机制:
1.从已设置过期时间的数据中挑选最近最少使用的数据淘汰
2.从已设置过期时间的数据中挑选将要过期的数据淘汰
3.从已设置过期时间的数据中任意选择数据淘汰
4.从已设置过期时间的数据中挑选最不经常使用的数据淘汰
5.移除最近最少使用的 key
6.移除最不经常使用的 key
7.任意选择数据淘汰
8.写入数据报错
14.Redis如何设置key的过期时间
redis作为缓存存储的时候,一般都要设置过期时间,否则垃圾数据会占用大量的内存
分开设置:先设置值,再设置时间(非原子操作,极端情况下会出现问题);
合并设置:一条命令设置过期时间和值(推荐)
命令:
设置过期时间:expire name 1000
查看剩余时间:ttl name
取消过期时间:persist name
15.Redis过期键的删除机制
惰性过期:当访问key时,检查是否过期,过期则删除;最大化节约cpu,但对内存不友好;极端情况下出现大量过期key未被访问,会占用大量内存
定期过期:每隔一段时间扫描一定数量的key,并清除已过期的key;通过调整扫描时间间隔和扫描耗时,可以让cpu和内存达到最优的平衡效果
16.Redis集群会有写操作丢失吗?为什么?
Redis并不能保证数据的强一致性,这意味这在实际中集群在特定的条件下可能会丢失写操作
条件:
- 过期key被清理
- 最大内存不足,导致 Redis 自动清理部分 key 以节省空间
- 主库故障后自动重启,从库自动同步
- 单独的主备方案,网络不稳定触发哨兵的自动切换主从节点,切换期间会有数据丢失
17.redis集群方案
主从模式:使用一个redis实例作为主机,其余的实例作为备份机,主机和从机的数据完全一致,主机支持数据的写入和读取等各项操作,而从机则只支持与主机数据的同步和读取
优缺点:
- 一个主节点可以同步多个从节点
- 难以支持在线扩容
- 不具备自动容错与恢复功能
- 主从之间的同步是以非阻塞的方式进行的,同步期间,客户端仍然可以提交查询或更新请求
- 主节点自动将数据同步到从节点,可以进行读写分离
哨兵模式:Redis集群站哨的,一旦发现问题能做出相应的应对处理;监控主节点、从节点是否正常运行当主节点出现故障时,能自动将一个从节点转换为主节点(大哥挂了,选一个小弟上位)多个哨兵可以监控同一个Redis,哨兵之间也会自动监控
Redis Cluster模式:Cluster采用无中心结构,客户端与redis节点直连,客户端不需要连接集群所有节点,连接集群中任何一个可用节点即可
18.Redis常见性能问题和解决方案?
- 主节点不要做任何持久化工作,包括内存快照和AOF日志文件,特别是不要启用内存快照做持久化
- 如果数据比较关键,某个从节点开启AOF备份数据,策略为每秒同步一次
- 为了主从复制的速度和连接的稳定性,主从节点最好在同一个局域网内
- 尽量避免在压力较大的主库上增加从库
- 为了主节点的稳定性,主从复制不要用图状结构,用单向链表结构更稳定,主节点挂了,可以立马启用Slave1做主节点,其他不变
19.Redis分布式锁是如何实现的?
分布式锁,即分布式系统中的锁,解决了分布式系统中控制共享资源访问的问题;
- 基于set命令的分布式锁
- 基于setnx、get、getset的分布式锁
- 基于RedLock的分布式锁
- 基于Redisson看门狗的分布式锁
20.Redis死锁情况,如何避免死锁
发生条件:
- ⼀个资源每次只能被⼀个线程使用
- ⼀个线程在阻塞等待某个资源时,不释放已占有资源
- ⼀个线程已经获得的资源,在未使用完之前,不能被强制剥夺
- 循环等待
解决:
- 使用事务时,尽量缩短事务的逻辑处理过程,及早提交或回滚事务
- 所有的程序都要有错误处理
- 对所有的脚本和程序都要仔细测试
- 优化程序,检查并避免死锁现象出现
- 设置死锁超时参数为合理范围,超过时间,自动放弃本次操作,避免进程悬挂
21.redis 6.0新增特性
新增特性:
- 多线程
- 客户端缓存
- 细粒度权限控制
- resp3协议的使用
- rdb文件加载更快
- 用于复制的rdb文件不再有用,将立刻被删除
22.redis 6.0为什么要改为多线程
随着硬件性能的提升,redis单个线程处理网络读写的速度跟不上底层网络硬件的速度。读写占用了大部分cpu的时间,瓶颈主要是网络的io消耗;优化的方向主要是:
1.优化网络 I/O 模块
2.提高机器内存读写的速度
提高机器内存读写的速度依赖于硬件,暂时无解;所以,Redis 采用多个 IO 线程来处理网络请求,提高网络请求处理的并行度。
Redis 多 IO 线程模型只用来处理网络读写请求,对于 Redis 的读写命令,依然是单线程处理
23.redis和redisson有什么关系?
Redisson是一个高级的分布式协调Redis客服端,能帮助用户在分布式环境中轻松实现一些Java的对象
相关文章:

java面试题(redis)
目录 1.redis主要消耗什么物理资源? 2.单线程为什么快 3.为什么要使用Redis 4.简述redis事务实现 5.redis缓存读写策略 6.redis除了做缓存,还能做些什么? 7.redis主从复制的原理 8.Redis有哪些数据结构?分别有哪些典型的应…...

Vue组件懒加载
组件懒加载 前言 组件懒加载最常用于异步加载大型/复杂组件或在需要时才进行加载 Vue 2和Vue 3均支持组件懒加载,本文将介绍如何在Vue 2和Vue 3中实现组件懒加载,和一些使用场景 1️⃣方法一:使用Webpack的代码分割能力 Vue 2和Vue 3都可以…...

Qt音视频开发42-网络推流(视频推流/本地摄像头推流/桌面推流/网络摄像头转发推流等)
一、前言 上次实现的文件推流,尽管优点很多,但是只能对现在存在的生成好的音视频文件推流,而现在更多的场景是需要将实时的视频流重新推流分发,用户在很多设备比如手机/平板/网页/电脑/服务器上观看,这样就可以很方便…...

更简单的存取Bean方式-@Bean方法注解
1.Bean方法存储 类注解是添加在某个类上的,那么方法注解是添加在某个方法前的 public class UserBeans {Beanpublic User user1(){User user new User();user.setUid(001);user.setUname("zhangsan");user.setAge(19);user.setPassword("123123");retur…...

边缘计算与AI布署应用电力物联网解决方案-RK3588开发平台
电力行业拥有规模庞大的各类设备,如电表、各类保护、采集、控制设备。面对分布式发电、储能、用户微网等一系列综合问题,边缘计算与AI布署可满足“端侧本地化”高效运用的需求,协助提升最后一公里运行效率。 瑞芯微RK3588J、内置独立NPU&…...

centos部署unity accelerator
参考 https://docs.unity3d.com/Manual/UnityAccelerator.html 方案1:下载Unity Accelerator 手动安装, unity-accelerator-app-v1.0.941g6b39b61.AppImage为下载的文件 1、放入服务器目录, chmod x unity-accelerator-app-v1.0.941g6b39b61.AppImage 2…...

HANA开发指南
建模方面 1、建模方式:图像化建模、SQL建模、CE语言建模 2、维护:SQL和CE比图形化建模更容易维护和修改 3、性能:图形化和CE会经过系统优化,性能一般优于SQL语言 4、可按需要设置参数、变量、Hierachy、聚合类型等 5、在S4系…...

请问你见过吐代码的泡泡吗(冒泡排序)
🤩本文作者:大家好,我是paperjie,感谢你阅读本文,欢迎一建三连哦。 🥰内容专栏:这里是《算法详解》,笔者用重金(时间和精力)打造,将算法知识一网打尽,希望可以…...

【VM服务管家】VM4.0平台SDK_2.1环境配置类
目录 2.1.1 环境配置:CSharp二次开发环境配置方法2.1.2 环境配置:Qt二次开发环境配置方法2.1.3 环境配置:MFC二次开发环境配置方法2.1.4 环境配置:VB.Net二次开发环境配置方法2.1.5 环境配置:运行出现Vm.Core.Solution…...

最新研究:可审计的具有拜占庭鲁棒的联邦学习方案
Y. Liang, Y. Li and B. -S. Shin, “Auditable Federated Learning With Byzantine Robustness,” in IEEE Transactions on Computational Social Systems, doi: 10.1109/TCSS.2023.3266019. 可免费下载:https://download.csdn.net/download/liangyihuai/87727720…...

JDK1.8下载、安装和环境配置教程
🎉🎉🎉点进来你就是我的人了博主主页:🙈🙈🙈戳一戳,欢迎大佬指点! 欢迎志同道合的朋友一起加油喔🦾🦾 目录 window系统安装java 下载JDK 配置环境变量 …...

天津超算,青索帮助文档
连接 第一步,点击 配置VPN(切换到局域网用)和机器(也就是各套超算系统)。 第二步,点击 机器 选择对应的机器。通常会在下方显示可用的机器,单击其中一个即可。如果只有一个机器,…...

SpringMVC的拦截器和异常处理器
目录 lerInterceptor 拦截器 1、拦截器的作用 2、拦截器的创建 3、拦截器的三个抽象方法 4、拦截器的配置 5、多个拦截器的执行顺序 SpringMVC的异常处理器 1、异常处理器概述 2、基于配置文件的异常处理 3、基于注解的异常处理 lerInterceptor 拦截器 1、拦截器的作…...

查看库文件是32位还是64位|查看lib是静态库还是导入库|判断是debug模式还是release模式
文章目录 dll位数查看lib位数查看查看lib库是静态库还是导入库dll库文件信息查看lib库文件内容查看dll库查看编译模式是debug还是release方法一方法二方法三 lib静态库查看编译模式是debug还是release方法一方法二 lib导入库查看编译模式是debug还是release查看Linux下的.a库&a…...

Python小姿势 - Python爬取数据的库——Scrapy
Python爬取数据的库——Scrapy 一、爬虫的基本原理 爬虫的基本原理就是模拟人的行为,使用指定的工具和方法访问网站,然后把网站上的内容抓取到本地来。 爬虫的基本步骤: 1、获取URL地址: 2、发送请求获取网页源码; 3、…...

[C++初阶]栈和队列_优先级队列的模拟实现 deque类 的理解
为了更好的理解优先级队列priority_queue,这里会同时进行栈和队列的提及 文章目录 简要概念(栈和队列)栈和队列的模拟实现与使用stack(栈)deque的理解和操作queue priority_queue(优先级队列)框…...

Spring是什么?关于Spring家族
初识Spring 什么是Spring? Spring是一个开源的Java企业级应用程序开发框架,由Rod Johnson于2003年创建,并在接下来的几年里得到了广泛的发展和应用。它提供了一系列面向对象的编程和配置模型,支持开发各种类型的应用程序&#x…...

自然语言处理数据集集锦(持续更新ing...)
诸神缄默不语-个人CSDN博文目录 最近更新时间:2023.4.26 最早更新时间:2023.4.25 文本摘要主题的数据集见我之前写的另一篇博文:文本摘要数据集的整理、总结及介绍(持续更新ing…) 智能司法主题的数据集我准备等项目…...

93、Dehazing-NeRF: Neural Radiance Fields from Hazy Images
简介 论文:https://arxiv.org/pdf/2304.11448.pdf 从模糊图像输入中恢复清晰NeRF 使用大气散射模型模拟有雾图像的物理成像过程,联合学习大气散射模型和干净的NeRF模型,用于图像去雾和新视图合成 通过将NeRF 3D场景的深度估计与大气散射模…...

JAVA子类与继承
目录 JAVA子类与继承 一、子类与父类: 二、子类与对象 三、成员变量的隐藏和方法重写 四、super关键字(P122) 五、final关键字 六、对象的上转型对象(P126) 七、继承与多态(P128) 八、abstract类和…...

62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库
文章目录 62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库62.1 创建数据库示例 62.2 查看数据库示例 62.3 选择数据库示例 62.4 删除数据库示例 62.5 备份数据库示例 62.6 恢复数据库示例 62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库 62.1 创建数据库…...

【分布式搜索引擎ES01】
分布式搜索引擎ES 分布式搜索引擎ES1.elasticsearch概念1.1.ES起源1.2.倒排索引1.2.1.正向索引1.2.2.倒排索引 1.3.es的一些概念1.3.1.文档和字段1.3.2.索引和映射1.3.3.mysql与elasticsearch 1.4.1安装es、kibana、IK分词器1.4.2扩展词词典与停用词词典 2.索引库操作2.1.mappi…...

1.3 鞅、停时和域流-鞅(布朗运动与随机计算【习题解答】)
Let X = ( x n , F n ) , n = 1 , ⋯ , N X=\left(x_n, \mathcal{F}_n\right), n=1, \cdots, N X...

十、ElasticSearch 实战 - 源码运行
一、概述 想深入理解 Elasticsearch,了解其报错机制,并有针对性的调整参数,阅读其源码是很有必要的。此外,了解优秀开源项目的代码架构,能够提高个人的代码架构能力 阅读 Elasticsearch 源码的第一步是搭建调试环境&…...

GPT-3 论文阅读笔记
GPT-3模型出自论文《Language Models are Few-Shot Learners》是OpenAI在2020年5月发布的。 论文摘要翻译:最近的工作表明,通过对大量文本进行预训练,然后对特定任务进行微调(fine-tuning),在许多NLP任务和基准测试上…...

方案解析丨数字人主播如何成为电商直播新标配
浙江省政府办公厅近日印发《关于进一步扩大消费促进高质量发展若干举措》支持电子商务直播发展。抢抓电子商务直播快速发展机遇,发展数字人虚拟主播、元宇宙新消费场景等新业态新模式。 随着电商直播快速发展,企业怎么高效地实现引流获客,成为…...

Python最全迭代器有哪些?
python中迭代器的使用是最广泛的,凡是使用for语句,其本质都是迭代器的应用。 从代码角度看,迭代器是实现了迭代器协议的对象或类。迭代器协议方法主要是两个: __iter__()__next__() __iter__()方法返回对象本身,他是…...

ESP32 网络计时器,包含自动保存
简介 本代码是基于ESP32开发板实现的一个计时器功能,具备倒计时、计时器时长选择、显示当前时间、有源蜂鸣器报警等功能。代码中使用了WiFi网络连接、NTP时间同步、EEPROM存储等功能。通过按钮控制计时器的开始、停止和计时器时长的选择。 运行原理概述 在ESP32开…...

【ChatGPT】阿里版 ChatGPT 突然官宣意味着什么?
Yan-英杰的主页 悟已往之不谏 知来者之可追 C程序员,2024届电子信息研究生 目录 阿里版 ChatGPT 突然官宣 ChatGPT 技术在 AI 领域的重要性 自然语言生成 上下文连续性 多语言支持 ChatGPT 未来可能的应用场景 社交领域 商业领域 编辑 医疗领域…...

IPEmotion控制模块-PID循环应用
IPEmotion专业版、开发版支持控制模块,并且该模块支持函数发生器、PID控制器、路由器、序列控制和序列控制块以及参考曲线生成器。本文主要针对PID(P:Proportional control 比例控制;I:Integral control 积分控制&…...