RedisInterview ...

Redis(一)

2019-02-18  本文已影响25人  FrankerSung

First And MOST Important

\color{red}{如果有错误还请在评论区提出🙏🙏 建议看下本文末尾的参考地址,有些具体的点应该比我总结的更为详尽,希望大家从中受益并尊重原创。🙂}

Redis 的线程模型是什么?redis采用多线程会有哪些问题?Redis为什么这么快?

  1. Redis为单线程工作模型。
    redis 内部使用文件事件处理器 ,它采用 IO 多路复用机制同时监听多个 socket。
    多个 socket 可能会并发产生不同的操作,每个操作对应不同的文件事件,但是 IO 多路复用程序会监听多个 socket,会将 socket 产生的事件放入队列中排队,事件分派器(dispatch)每次从队列中取出一个事件,把该事件交给对应的事件处理器(handle)进行处理。

文件事件处理器的结构包含 4 个部分:

  1. Redis速度快的原因

Redis如何使用Redis实现分布式锁

一般不要使用,使用zookeeper。

Redis 的过期策略都有哪些?

redis 过期策略是:定期删除+惰性删除。
定期删除:redis 默认每隔 100ms 就随机抽取部分设置过期时间的 key,检查其是否过期,如果过期就删除。
惰性删除:获取某个 key 的时候,redis 会在获取前判断这个 key 是否设置了过期时间并已经过期了,如果过期了会触发删除。
显然,这样可能会造成大量的过期 key 在内存里,浪费了资源,此时,redis 内存淘汰机制便上场了:

Redis支持哪几种数据结构?分别在哪些场景下使用比较合适?

redis 主要有以下几种数据类型:

  1. string
    这是最简单的类型,就是普通的 set 和 get,做简单的 KV 缓存。
  2. hash
    这个是类似 map 的一种结构,这个一般就是可以将结构化的数据,比如一个对象(前提是这个对象没嵌套其他的对象)给缓存在 redis 里,然后每次读写缓存的时候,可以就操作 hash 里的某个字段。
  3. list
    list 是有序列表,比如可以通过 list 存储一些列表型的数据结构,类似粉丝列表、文章的评论列表之类的东西。
    比如可以通过 lrange 命令,读取某个闭区间内的元素,可以基于 list 实现分页查询,这个是很棒的一个功能,基于 redis 实现简单的高性能分页,可以做类似微博那种下拉不断分页的东西,性能高,就一页一页走。
  4. set
    set 是无序集合,自动去重。可以基于 set 做交集、并集、差集的操作。
  5. sorted set
    sorted set 是排序的 set,去重但可以排序,写进去的时候给一个分数(score),自动根据分数排序。

Redis 的哨兵?

哨兵是 redis 集群机构中非常重要的一个组件,主要有以下功能:

当哨兵集群中的大多数哨兵都认为master挂掉时,一个哨兵被选择执行主备切换任务。
选举slave为master,选举因素如下:

Redis的持久化方式?优缺点?底层如何实现?

RDB:RDB 持久化机制,是对 redis 中的数据执行周期性的持久化。
AOF:AOF 机制对每条写入命令作为日志,以 append-only 的模式写入一个日志文件中,在 redis 重启的时候,可以通过回放 AOF 日志中的写入指令来重新构建整个数据集。

  1. RDB 优缺点
  1. AOF 优缺点

RDB和AOF如何选择?
可以综合使用 AOF 和 RDB 两种持久化机制,用 AOF 来保证数据不丢失,作为数据恢复的第一选择; 用 RDB 来做不同程度的冷备,在 AOF 文件都丢失或损坏不可用的时候,还可以使用 RDB 来进行快速的数据恢复。

Redis 的雪崩和穿透?如何解决?

雪崩:缓存机器挂掉
穿透:缓存不命中,打到关系数据库上。

缓存雪崩解决方案:

缓存穿透解决方案:

如何保证缓存与数据库的双写一致性?

采用Cache-Aside pattern

Redis 的并发竞争问题是什么?如何解决这个问题?

Redis为单进程单线程模式,采用队列模式将并发访问变为串行访问。Redis本身没有锁的概念,Redis对于多个客户端连接并不存在竞争,但是在客户端对Redis进行并发访问时会发生连接超时、数据转换错误、阻塞、客户端关闭连接等问题,这些问题均是由于客户端连接异常造成。

对此有2种解决方法:

Redis 事务的 CAS 方案?


参考资料
https://github.com/doocs/advanced-java/blob/master/docs/high-concurrency/redis-persistence.md
http://www.cnblogs.com/rjzheng/p/9041659.html
https://www.jianshu.com/p/0244a875aa26

上一篇下一篇

猜你喜欢

热点阅读