1. redis是单线程的吗?为什么这么快?
答:redis并不是完全单线程。我们常说的redis单线程主要是指Redis的网络IO 和键值对读写是由一个线程来完成的,这也是redis对外提供的存储服务的主要流程。但 Redis 的其他功能,比如持久化、key过期异步删除、集群数据同步等,其实是由额外的线程执行的!
至于redis单线程快的原因是:redis把所有的数据都存储在内存中,所有运算都是内存级别的运算,再者单线程避免了线程切换的性能损耗问题,所以redis是比较快的。正因为 Redis 是单线程,所以要小心使用 Redis 指令,对于那些耗时的指令(比如 keys *),一定要谨慎使用,一不小心就可能会导致 Redis 卡顿。
2. Redis 单线程如何处理那么多的并发客户端连接?
Redis的IO多路复用:redis利用epoll来实现IO多路复用,将连接信息和事件放到队列中,依次放到文件事件分派器,事件分派器将事件分发给事件处理器。