Redis面试题 70道

这是一篇关于Redis面试的总结,涵盖了线程模型的探讨,详细解释了Redis的事务处理机制,并深入研究了Redis的集群解决方案,对于准备Redis面试和性能优化的开发者极具参考价值。
摘要由CSDN通过智能技术生成
概述

 

1. 什么是 Redis
Redis 是一个使用 C 语言写成的,开源的高性能 key-value 非关系缓存数据库。它支持存储的 value
类型相对更多,包括 string( 字符串 ) list( 链表 ) set( 集合 ) zset(sorted set -- 有序集合 )
hash (哈希类型)。 Redis 的数据都基于缓存的,所以很快,每秒可以处理超过 10 万次读写操
作,是已知性能最快的 Key-Value DB Redis 也可以实现数据写入磁盘中,保证了数据的安全不丢
失,而且 Redis 的操作是原子性的。
2. Redis 有哪些优缺点?
优点
读写性能优异, Redis 能读的速度是 110000 /s ,写的速度是 81000 /s
支持数据持久化,支持 AOF RDB 两种持久化方式。
支持事务, Redis 的所有操作都是原子性的,同时 Redis 还支持对几个操作合并后的原子性执
行。
数据结构丰富,除了支持 string 类型的 value 外还支持 hash set zset list 等数据结构。
支持主从复制,主机会自动将数据同步到从机,可以进行读写分离。
缺点
数据库容量受到物理内存的限制,不能用作海量数据的高性能读写,因此 Redis 适合的场景主
要局限在较小数据量的高性能操作和运算上。
Redis 不具备自动容错和恢复功能,主机从机的宕机都会导致前端部分读写请求失败,需要
等待机器重启或者手动切换前端的 IP 才能恢复。
主机宕机,宕机前有部分数据未能及时同步到从机,切换 IP 后还会引入数据不一致的问题,
降低了系统的可用性。
Redis 较难支持在线扩容,在集群容量达到上限时在线扩容会变得很复杂。为避免这一问
题,运维人员在系统上线时必须确保有足够的空间,这对资源造成了很大的浪费。
3. 使用 redis 有哪些好处?
(1) 速度快,因为数据存在内存中,类似于 HashMap HashMap 的优势就是查找和操作的时间复
杂度都很低
(2) 支持丰富数据类型,支持 string list set sorted set hash
(3) 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行
(4) 丰富的特性:可用于缓存,消息,按 key 设置过期时间,过期后将会自动删除
4. 为什么要用 Redis / 为什么要用缓存
主要从 高性能 高并发 这两点来看待这个问题。
高性能:
假如用户第一次访问数据库中的某些数据。这个过程会比较慢,因为是从硬盘上读取的。将
该用户访问的数据存在数缓存中,这样下一次再访问这些数据的时候就可以直接从缓存中获
取了。操作缓存就是直接操作内存,所以速度相当快。如果数据库中的对应数据改变的之
后,同步改变缓存中相应的数据即可!
高并发:
直接操作缓存能够承受的请求是远远大于直接访问数据库的,所以我们可以考虑把数据库中
的部分数据转移到缓存中去,这样用户的一部分请求会直接到缓存这里而不用经过数据库。
5. 为什么要用 Redis 而不用 map/guava 做缓存 ?
缓存分为本地缓存和分布式缓存。以 Java 为例,使用自带的 map 或者 guava 实现的是本地缓
存,最主要的特点是轻量以及快速,生命周期随着 jvm 的销毁而结束,并且在多实例的情况下,
每个实例都需要各自保存一份缓存,缓存不具有一致性。
使用 redis memcached 之类的称为分布式缓存,在多实例的情况下,各实例共用一份缓存数
据,缓存具有一致性。缺点是需要保持 redis memcached 服务的高可用,整个程序架构上较为
复杂。
6. Redis 为什么这么快
1 、完全基于内存,绝大部分请求是纯粹的内存操作,非常快速。数据存在内存中,类似于
HashMap HashMap 的优势就是查找和操作的时间复杂度都是 O(1)
2 、数据结构简单,对数据操作也简单, Redis 中的数据结构是专门进行设计的;
3 、采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换
而消耗 CPU ,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致
的性能消耗;
4 、使用多路 I/O 复用模型,非阻塞 IO
5 、使用底层模型不同,它们之间底层实现方式以及与客户端之间通信的应用协议不一样, Redis
直接自己构建了 VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请
求;
7. Redis 有哪些数据类型
Redis 主要有 5 种数据类型,包括 String List Set Zset Hash ,满足大部分的使用要求

 

8. Redis 的应用场景
计数器
可以对 String 进行自增自减运算,从而实现计数器功能。 Redis 这种内存型数据库的读写性能非常高,
很适合存储频繁读写的计数量。
缓存
将热点数据放到内存中,设置内存的最大使用量以及淘汰策略来保证缓存的命中率。
会话缓存
可以使用 Redis 来统一存储多台应用服务器的会话信息。当应用服务器不再存储用户的会话信息,也就
不再具有状态,一个用户可以请求任意一个应用服务器,从而更容易实现高可用性以及可伸缩性。 全页缓存( FPC
除基本的会话 token 之外, Redis 还提供很简便的 FPC 平台。以 Magento 为例, Magento 提供一个插件
来使用 Redis 作为全页缓存后端。此外,对 WordPress 的用户来说, Pantheon 有一个非常好的插件 wp
redis ,这个插件能帮助你以最快速度加载你曾浏览过的页面。
查找表
例如 DNS 记录就很适合使用 Redis 进行存储。查找表和缓存类似,也是利用了 Redis 快速的查找特
性。但是查找表的内容不能失效,而缓存的内容可以失效,因为缓存不作为可靠的数据来源。
消息队列 ( 发布 / 订阅功能 )
List 是一个双向链表,可以通过 lpush rpop 写入和读取消息。不过最好使用 Kafka
RabbitMQ 等消息中间件。
分布式锁实现
在分布式场景下,无法使用单机环境下的锁来对多个节点上的进程进行同步。可以使用 Redis 自带的
SETNX 命令实现分布式锁,除此之外,还可以使用官方提供的 RedLock 分布式锁实现。
其它
Set 可以实现交集、并集等操作,从而实现共同好友等功能。 ZSet 可以实现有序性操作,从而实
现排行榜等功能。
9. 持久化
什么是 Redis 持久化? 持久化就是把内存的数据写到磁盘中去,防止服务宕机了内存数据丢失。
10. Redis 的持久化机制是什么?各自的优缺点?
Redis 提供两种持久化机制 RDB (默认) 和 AOF 机制 :
RDB :是 Redis DataBase 缩写快照
RDB Redis 默认的持久化方式。按照一定的时间将内存的数据以快照的形式保存到硬盘中,对应
产生的数据文件为 dump.rdb 。通过配置文件中的 save 参数来定义快照的周期。

 

优点:
1 、只有一个文件 dump.rdb ,方便持久化。
2 、容灾性好,一个文件可以保存到安全的磁盘。
3 、性能最大化, fork 子进程来完成写操作,让主进程继续处理命令,所以是 IO 最大化。使用单
独子进程来进行持久化,主进程不会进行任何 IO 操作,保证了 redis 的高性能
4. 相对于数据集大时,比 AOF 的启动效率更高。
缺点: 1 、数据安全性低。 RDB 是间隔一段时间进行持久化,如果持久化之间 redis 发生故障,会发生数
据丢失。所以这种方式更适合数据要求不严谨的时候 )
2 AOF Append-only fifile) 持久化方式: 是指所有的命令行记录以 redis 命令请 求协议的格式
完全持久化存储 ) 保存为 aof 文件。
AOF :持久化:
AOF 持久化 ( Append Only File 持久化 ) ,则是将 Redis 执行的每次写命令记录到单独的日志文件
中,当重启 Redis 会重新将持久化的日志中文件恢复数据。
当两种方式同时开启时,数据恢复 Redis 会优先选择 AOF 恢复

 

优点:
1 、数据安全, aof 持久化可以配置 appendfsync 属性,有 always ,每进行一次 命令操作就记录
aof 文件中一次。
2 、通过 append 模式写文件,即使中途服务器宕机,可以通过 redis-check-aof 工具解决数据一
致性问题。
3 AOF 机制的 rewrite 模式。 AOF 文件没被 rewrite 之前(文件过大时会对命令 进行合并重
写),可以删除其中的某些命令(比如误操作的 flflushall )
缺点:
1 AOF 文件比 RDB 文件大,且恢复速度慢。
2 、数据集大的时候,比 rdb 启动效率低。
俩种持久化的优缺点是什么?
AOF 文件比 RDB 更新频率高,优先使用 AOF 还原数据。
AOF RDB 更安全也更大
RDB 性能比 AOF
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值