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

redis面试题合集-基础

前言

又来到每日的复习时刻,昨天我们学习了mysql相关基础知识,还有分布式数据库介绍(后续总结时再持续更新)。今日继续学习缓存杀器:redis

redis基础面试题合集

  1. 什么是Redis?

Redis是一个开源的、内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。它支持多种类型的数据结构,如字符串、哈希表、列表、集合和有序集合等,并提供了丰富的原子操作来操作这些数据结构。

  1. Redis的主要特点是什么?

速度快:Redis将数据存储在内存中,因此读写速度非常快。
支持丰富的数据结构:Redis支持多种类型的数据结构,可以灵活地满足不同的应用需求。
原子性:Redis的所有操作都是原子性的,这保证了在并发环境下的数据一致性。
持久化:Redis提供了多种持久化方式,可以将内存中的数据保存到磁盘中,以防止数据丢失。
分布式:Redis支持分布式部署,可以方便地扩展系统的处理能力。

  1. Redis支持哪些数据类型?

字符串(Strings)
哈希表(Hashes)
列表(Lists)
集合(Sets)
有序集合(Sorted Sets)
位图(Bitmaps)
HyperLogLogs
geo

  1. Redis的持久化方式有哪些?

Redis的持久化是将内存中的数据存储到硬盘上的过程,以便在服务器重启或发生故障时能够恢复数据
RDB(Redis DataBase):在指定的时间间隔内生成数据集的时间点快照(Snapshot)。这种方式的优点是生成的数据量较小,适合定期持久化大量数据的情况。但是,如果数据量很大,生成快照的过程可能会导致内存占用过高,甚至影响redis的正常运行。
AOF(Append Only File):记录服务器接收到的所有写操作命令,并在服务器启动时,通过重新执行这些命令来重建数据集。这种方式可以保证数据的完整性和安全性但是持久化过程可能会比较慢,因为需要记录所有的写操作。
除了RDB和AOF两种持久化方式外,Redis还提供了多种配置选项和策略来优化持久化的性能和数据恢复的可靠性。例如,可以通过配置save和bgsave命令来控制RDB持久化的频率和触发条件,通过配置appendfsync选项来控制AOF持久化的方式等。
总的来说,Redis的持久化是为了确保数据的可靠性和安全性而设计的,可以根据实际需求选择适合的持久化方式和策略来优化性能和可靠性。

  1. Redis的事务是如何实现的?

Redis的事务是通过MULTI、EXEC和DISCARD命令来实现的。MULTI命令用于开启一个事务,EXEC命令用于执行事务中的所有命令,DISCARD命令用于取消事务。在事务执行期间,其他客户端的命令将会被阻塞,直到事务执行完毕。

  1. Redis的并发竞争问题如何解决?

Redis为单进程单线程模式,采用队列模式将并发访问变为串行访问,因此不需要解决并发竞争问题。但是,在客户端对Redis进行并发访问时,可能会发生连接超时、数据转换错误、阻塞、客户端关闭连接等问题。这些问题可以通过连接池化、使用内部锁等方式来解决

  1. 如何保证Redis的高可用性?

部署多个Redis实例,实现主从复制或集群部署,提高系统的容错能力。
使用Sentinel或Redis Cluster等工具进行自动故障转移和负载均衡。
对Redis进行监控和报警,及时发现和处理问题。
对重要数据进行备份和恢复,以防止数据丢失。

  1. Redis的淘汰策略有哪些?

volatile-lru:从已设置过期时间的数据集中挑选最近最少使用的数据淘汰。
volatile-ttl:从已设置过期时间的数据集中挑选将要过期的数据淘汰。
volatile-random:从已设置过期时间的数据集中任意选择数据淘汰。
allkeys-lru:从数据集中挑选最近最少使用的数据淘汰。
allkeys-random:从数据集中任意选择数据淘汰。
no-eviction:禁止驱逐数据。

  1. Redis的性能优化有哪些方法?

优化数据结构和存储方式,减少内存占用和IO操作
使用连接池化技术,减少连接创建和销毁的开销。
热点数据进行缓存和预加载,减少数据库访问次数。
使用Pipeline技术批量处理命令,减少网络传输次数和延迟
对Redis进行监控和调优,及时发现和解决性能瓶颈。

寄语

redis基础知识就复习到这里,数据结构的实现、集群相关以及高可用等后文将持续介绍。期待我们应用这些知识在职业生涯中更进一步。

相关文章:

redis面试题合集-基础

前言 又来到每日的复习时刻,昨天我们学习了mysql相关基础知识,还有分布式数据库介绍(后续总结时再持续更新)。今日继续学习缓存杀器:redis redis基础面试题合集 什么是Redis? Redis是一个开源的、内存中…...

(Unity)C# 中的字符串格式化

前言 在软件开发中,理解和掌握字符串的格式化及调试技巧对于编写高效和可维护的代码至关重要。 字符串插值 ($ 符号) 在 C# 中,字符串插值是通过在字符串前加 $ 符号来实现的。这允许我们将变量、表达式或函数调用直接嵌入到字符串中。 string name &qu…...

【项目日记(五)】第二层: 中心缓存的具体实现(上)

💓博主CSDN主页:杭电码农-NEO💓   ⏩专栏分类:项目日记-高并发内存池⏪   🚚代码仓库:NEO的学习日记🚚   🌹关注我🫵带你做项目   🔝🔝 开发环境: Visual Studio 2022 项目日…...

使用PSIM软件生成DSP28335流水灯程序

最近在学习DSP28335芯片,然后在使用PSIM仿真软件时发现这个仿真软件也支持28335芯片,于是就想学习下如何在PSIM软件中使用DSP28335芯片。在PSIM自带的官方示例中有使用DSP28335芯片的相关例子。 工程下载链接 https://download.csdn.net/download/qq_20…...

【iOS ARKit】人脸检测追踪基础

在计算机人工智能(Artificial Inteligence,AI)物体检测识别领域,最先研究的是人脸检测识别,目前技术发展最成熟的也是人脸检测识别。人脸检测识别已经广泛应用于安防、机场、车站、闸机、人流控制、安全支付等众多社会领域&#x…...

ES的一些名称和概念总结

概念 先看看ElasticSearch的整体架构: 一个 ES Index 在集群模式下,有多个 Node (节点)组成。每个节点就是 ES 的Instance (实例)。每个节点上会有多个 shard (分片), P1 P2 是主分片, R1 R2…...

Javaweb之SpringBootWeb案例之阿里云OSS服务集成的详细解析

2.3.3 集成 阿里云oss对象存储服务的准备工作以及入门程序我们都已经完成了,接下来我们就需要在案例当中集成oss对象存储服务,来存储和管理案例中上传的图片。 在新增员工的时候,上传员工的图像,而之所以需要上传员工的图像&…...

【GitHub项目推荐--不错的 Go 学习项目】【转载】

开源实时性能分析平台 Pyroscope 是基于 Go 的开源实时性能分析平台,在源码中添加几行代码 pyroscope 就能帮你找出源代码中的性能问题和瓶颈、CPU 利用率过高的原因,调用树展示帮助你理解程序,支持 Go、Python、Ruby 语言。 Pyroscope 可以…...

【Git】windows系统安装git教程和配置

一、何为Git Git(读音为/gɪt/)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。 二、git安装包 有2种版本,Git for Windows Setup和Git for Windows Portable(便携版)两个版本都可以。 三、Git for Windows Por…...

办公技巧:PPT制作技巧分享,值得收藏

目录 1、黑屏/白屏你用过么 2、图形组合替代动画刷 3、等距分布图形元素 4、快速统一字体 5、文本框也是可以改的 6、批量修改形状 7、搞定“怎么也选不中” 8、妙用CtrlD 9、图片阵列怎么做 10、临时放大某一区域 11、Word快速导入PPT 12、炫酷小人怎么做的&#…...

Google Chrome RCE漏洞 CVE-2020-6507 和 CVE-2024-0517 流程分析

本文深入研究了两个在 Google Chrome 的 V8 JavaScript 引擎中发现的漏洞,分别是 CVE-2020-6507 和 CVE-2024-0517。这两个漏洞都涉及 V8 引擎的堆损坏问题,允许远程代码执行。通过EXP HTML部分的内存操作、垃圾回收等流程方式实施利用攻击。 CVE-2020-…...

前端怎么监听手机键盘是否弹起

摘要: 开发移动端中,经常会遇到一些交互需要通过判断手机键盘是否被唤起来做的,说到判断手机键盘弹起和收起,应该都知道,安卓和ios判断手机键盘是否弹起的写法是有所不同的,下面讨论总结一下两端的区别以及…...

本地生活服务平台加盟前景与市场分析

随着短视频市场的的不断发展,人们的生活方式也在发生着巨大的变化。在这个数字化的时代,越来越多的创业者开始注重本地生活服务,这也为创业者提供了一个绝佳的商机。加盟本地生活服务平台,既可以抓住这波风口,又可以满…...

蓝桥杯备战——7.DS18B20温度传感器

1.分析原理图 通过上图我们可以看到DS18B20通过单总线接到了单片机的P14上。 2.查阅DS18B20使用手册 比赛的时候是会提供DS18B20单总线通讯协议的代码,但是没有提供读取温度数据的代码,所以还是需要我们去查看手册,我只把重要部分截下来了 …...

黑盒测试用例的具体设计方法(7种)

7种常见的黑盒测设用例设计方法,分别是等价类、边界值、错误猜测法、场景设计法、因果图、判定表、正交排列。 (一)等价类 1.概念 依据需求将输入(特殊情况下会考虑输出)划分为若干个等价类,从等价类中选…...

docker镜像管理命令

文章目录 docker imagesdocker builddocker rmidocker tagdocker savedocker loaddocker importdocker commitdocker login/logoutdocker pulldocker pushdocker search总结 docker images 列出本地镜像。 docker images [OPTIONS] [REPOSITORY[:TAG]]OPTIONS说明&#xff1a…...

深入理解STM32中断处理机制

深入理解STM32中断及其使用方法(基于HAL库) STM32微控制器作为一款强大的嵌入式系统芯片,在各种应用中都需要使用中断来实现实时响应和处理各种事件。本文将深入讨论STM32中断的概念、HAL库的中断处理机制以及如何在STM32CubeMX中配置和使用…...

基于机器学习的地震预测(Earthquake Prediction with Machine Learning)

基于机器学习的地震预测(Earthquake Prediction with Machine Learning) 一、地震是什么二、数据组三、使用的工具和库四、预测要求五、机器学习进行地震检测的步骤六、总结 一、地震是什么 地震几乎是每个人都听说过或经历过的事情。地震基本上是一种自…...

《30天自制操作系统》 第一周(D1-D7) 笔记

前言:这是我2023年5月份做的一个小项目,最终是完成了整个OS。笔记的话,只记录了第一周。想完善,却扔在草稿箱里许久。最终决定,还是发出来存个档吧。 一、汇编语言 基础指令 MOV: move赋值,数据传送指令…...

SQL注入:报错注入

SQL注入系列文章:初识SQL注入-CSDN博客 SQL注入:联合查询的三个绕过技巧-CSDN博客 目录 什么是报错注入? 报错注入常用的3个函数 UpdateXML ExtractValue Floor rand(随机数) floor(向上取整&…...

K8s 安装部署-Master和Minion(Node)文档

K8s 安装部署-Master和Minion(Node)文档 操作系统版本:CentOS 7.4 Master :172.20.26.167 Minion-1:172.20.26.198 Minion-2:172.20.26.210(后增加节点) ETCD:172.20.27.218 先安装部署ETC…...

OpenAI 降低价格并修复拒绝工作的“懒惰”GPT-4,另外ChatGPT 新增了两个小功能

OpenAI降低了GPT-3.5 Turbo模型的API访问价格,输入和输出价格分别降低了50%和25%。这对于使用API进行文本密集型应用程序的用户来说是一个好消息。 OpenAI官网:OpenAI AIGC专区:aigc 教程专区:AI绘画,AI视频&#x…...

springboot+value静态属性获取配置文件中的值的操作方法

1.配置类需要让spring管理 2.set方法不要加static 3.如果静态属性是private修饰,则在使用的时候,需要 类名.getXXX方法 如果静态属性是public修饰,则在使用的时候,需要 类名.属性名 import org.springframework.beans.factory.an…...

Prometheus 架构全面解析

在本指南中,我们将详细介绍 Prometheus 架构。 Prometheus 是一个用 Golang 编写的开源监控和告警系统,能够收集和处理来自各种目标的指标。您还可以查询、查看、分析指标,并根据阈值收到警报。 此外,在当今世界,可观…...

把批量M3U8网络视频地址转为MP4视频

在数字媒体时代,视频格式的转换已成为一项常见的需求。尤其对于那些经常处理网络视频的用户来说,将M3U8格式的视频转换为更常见的MP4格式是一项必备技能。幸运的是,现在有了固乔剪辑助手这款强大的工具,这一过程变得异常简单。下面…...

联合 Maxlinear 迈凌 与 Elitestek 易灵思 - WPI 世平推出基于 FPGA 芯片的好用高效电源解决方案

近期 WPI 世平公司联合 Maxlinear 迈凌电源产品搭配 Elitestek 易灵思 FPGA 共同合作推出基于 FPGA 芯片的好用高效电源解决方案。 Elitestek 易灵思 FPGA 核心产品有 2 大系列 : Trion 系列与钛金系列。Trion 系列主要特点是 : 1. 40nm 工艺 2. 超低功耗 ( 可低至竞争对手的 …...

Keycloak - docker 运行 前端集成

Keycloak - docker 运行 & 前端集成 这里的记录主要是跟我们的项目相关的一些本地运行/测试,云端用的 keycloak 版本不一样,不过本地我能找到的最简单的配置是这样的 docker 配置 & 运行 keycloak keycloak 有官方(Red Hat Inc.)的镜像&#…...

架构篇27:如何设计计算高可用架构?

文章目录 主备主从集群小结计算高可用的主要设计目标是:当出现部分硬件损坏时,计算任务能够继续正常运行。因此计算高可用的本质是通过冗余来规避部分故障的风险,单台服务器是无论如何都达不到这个目标的。所以计算高可用的设计思想很简单:通过增加更多服务器来达到计算高可…...

Python 有用的库模块

简介 Python中有许多常用的库或者模块,在写代码的时候或多或少会遇到,本文对其进行总结,方便日后查阅。 pprint Python中的pprint模块是用于打印数据结构(如字典,列表等)的模块,提供了一种以…...

vivado DDS学习

实现DDS通常有两种方式,一种是读取ROM存放的正弦/余弦信号的查表法,另一种是用DDS IP核。这篇学习笔记中,我们要讲解说明的是VIVADO DDS IP核的应用。 目前本篇默认Phase Generator and SIN/COS LUT(DDS)的standard模式…...

wordpress 注册邮件设置/互动营销名词解释

在我们使用电脑的时候,有些情况下可能就会遇到我们的电脑出现没有启动服务器服务的情况。对于这种问题小编觉得可能是因为我们系统本身就没有开启服务器服务,只要我们手动开启即可。可以在运行中打开services.msc服务,然后进行相关的设置即可…...

国家城乡和住房建设部网站/优化设计卷子答案

一、引入依赖 需要JAVA Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台源码 一零三八七七四六二六 //起步依赖 compile(org.springframework.cloud:spring-cloud-starter) //zipkin compile(io.zipkin.java:zipkin-server) //zipkin的web界面 compile(io.zipkin.j…...

金华市建设局网站贾润根/sem优化推广

1.复制:整体拷贝文件; 2.安装:一个一个拷贝文件;...

做检测设备的网站有哪些/自己开发网站

常用路由协议的梳理静态路由:优点:无需进行路由交换、更高的安全性、有的情况下必须使用静态路由,如DDR、使用NAT技术的网络环境。缺点:网络的扩展性能差、配置烦琐。动态路由:(Rip、OSPF、EIGRP、BGP)Rip具…...

旅行网站排名前十名/个人怎么做百度竞价

分别尝试采用Quartus和ISE调用第三方综合软件Synplify进行综合。 【软件版本】 Quartus II 13.0 (SP)、ISE 14.4 、Synplify 201303。 【问题描述】 一开始两个软件调用均显示不成功,quartus显示encountered errors,ISE显示failed。 【解决方法】 要正确…...

内江做网站的公司/百度指数功能模块有哪些

错误提示:System.Data.OleDb.OleDbException: 字段太小而不能接受所要添加的数据的数量。“/”应用程序中的服务器错误。-------------------------------------------------------------------------------- 字段太小而不能接受所要添加的数据的数量。试着插入或粘…...