参考文献
- https://zhuanlan.zhihu.com/p/599663544
基础知识
1. Redis的数据类型及使用场景
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
2. Redis为什么快
- Redis 是基于内存的,绝大部分请求都是纯粹的内存操作。
- 数据结构以及底层编码方式,Redis 的数据结构是专门进行设计的,数据结构简单,对数据操作也简单。
- 采用单线程 + IO 多路复用的模型。
- 单线程避免了不必要的上下文切换和锁竞争
- IO 多路复用模型,非阻塞 IO。
- 底层模型不同,它们之间底层实现方式以及客户端之间的通信的应用协议不一样,redis 直接自己构建了 VM 机制。因为一般的系统调用,会浪费一定的时间去移动和请求(基本不用,享受纯内存操作)
- 计算向数据移动,与 memcache 对比。(在 IO 上优化)
- 移动数据成本大,移动计算成本小
3. Redis 是单线程还是多线程
无论什么版本,工作线程就是一个,但是在6.x 高版本出现了 IO 多线程
单线程,满足 redis 的串行原子,只不过 IO 多线程后,把 输入/输出 放到更多的线程里去并行。这样做的好处在于:
- 执行时间缩短,更快
- 更好地压榨系统及硬件地资源(网卡能够高效的使用)
简单来说,为什么使用多线程?
答:充分利用多核,提高网络吞吐
4. 那么Redis 6.0 之前为什么不使用多线程?
- Redis 的性能瓶颈不在于 CPU,主要在于内存和网络
- 如果吞吐量不能满足我们的需求,更推荐的做法是使用分片的方式将不同的请求交给不同的 Redis 服务器来处理,而不是在同一个 Redis 服务中引入大量的多线程操作
- 单线程编程实现简单并且容易维护,方便开发和调试。并且使用单线程 + 文件事件处理器 也能并发的处理客户端的请求。
- 多线程会存在死锁、上下文切换等问题,甚至会影响性能
5. 多线程有缺点,为什么又引入了多线程
虽然 Redis 中引入了多线程,但是 Redis 的多线程只是把网络 IO 这类耗时的操作放到多线程中执行,充分利用多核,提高网络吞吐,更好地压榨系统及硬件地资源(网卡能够高效的使用)。执行命令仍然是单线程顺序执行,不需要担心线程安全问题。