Redis面试总结
一,使用Redis有哪些好处
1,速度快,因为数据库存在内存中
2,支持丰富的数据类型,支持String ,list ,set ,sorted set, hash
3,支持事务,操作都是原子性,所谓的原子性就是对数据要么全部执行,要么全不执行
4,丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除
二,Redis相比memcached有哪些优势
1,memecached所有的值均是简单的字符串,Redis作为其替代者,支持更为丰富数据类型
2,Redis的速度比memchched快的很多
3,Redis可以持久化其数据
4,Redis支持数据的备份,即master-slave模式的数据备份
5,使用底层原理不同
他们之间底层实现方式以及与客户端之间通信的应用协议不一样,
6,value大小:Redis最大可以达到1GB,而memcache只有1MB
三,Redis常见性能问题和解决方案
(1) Master最好不要做任何持久化工作,如RDB内存快照和AOF日志文件
(Master写内存快照,save命令调度rdbSave函数,会阻塞主线程的工作,当快照比较大时对性能影响是非常大的,会间断性暂停服务,所以Master最好不要写内存快照;AOF文件过大会影响Master重启的恢复速度)
(2):如果数据比较重要,某个Slave开启AOF备份数据,策略设置为每秒同步一次
(3):为了主从复制的速度和链接的稳定性,Master和Slave最好在同一个局域网内
(4):尽量避免在压力很大的主从库上增加从库
(5) 主从复制不要用图状结构,用单向链表结构更为稳定,即:Master <- Slave1 <- Slave2 <- Slave3…
这样的结构方便解决单点故障问题,实现Slave对Master的替换。如果Master挂了,可以立刻启用Slave1做Master,其他不变。
三,Redis的一些其他特性
(1)Redis是单进程单线程
Redis利用队列技术奖开发访问变串行访问,消除了传统数据库串行控制的开销
(2)读写分离模型
通过增加Slave DB的数量,读的性能可以线性增长。为了避免Master DB的单点故障,集群一般都会采用两台Master DB做双机热备,所以整个集群的读和写的可用性都非常高。
读写分离架构的缺陷在于,不管是Master还是Slave,每个节点都必须保存完整的数据,如果在数据量很大的情况下,集群的扩展能力还是受限于单个节点的存储能力,而且对于Write-intensive类型的应用,读写分离架构并不适合。
(3)数据分片模型
为了解决读写分离模型的缺陷,可以将数据分片模型应用进来。
可以将每个节点看成都是独立的master,然后通过业务实现数据分片。
结合上面两种模型,可以将每个master设计成由一个master和多个slave组成的模型。
(4)Redis的回收策略
volatile-lru:从已设置过期时间的数据集(server.db[i].expires)中挑选最近最少使用的数据淘汰
volatile-ttl:从已设置过期时间的数据集(server.db[i].expires)中挑选将要过期的数据淘汰
volatile-random:从已设置过期时间的数据集(server.db[i].expires)中任意选择数据淘汰
allkeys-lru:从数据集(server.db[i].dict)中挑选最近最少使用的数据淘汰
allkeys-random:从数据集(server.db[i].dict)中任意选择数据淘汰
no-enviction(驱逐):禁止驱逐数据
注意这里的6种机制,volatile和allkeys规定了是对已设置过期时间的数据集淘汰数据还是从全部数据集淘汰数据,后面的lru、ttl以及random是三种不同的淘汰策略,再加上一种no-enviction永不回收的策略。
使用策略规则:
1、如果数据呈现幂律分布,也就是一部分数据访问频率高,一部分数据访问频率低,则使用allkeys-lru
2、如果数据呈现平等分布,也就是所有的数据访问频率都相同,则使用allkeys-random