为什么Redis 单线程却能支撑高并发

一.纯内存操作

二.核心是基于非阻塞的 IO 多路复用机制

三.单线程反而避免了多线程的频繁上下文切换问题

个人理解 1:db操作需要操作磁盘 涉及到io所有效率肯定比内存效率低

               2:个人理解就是,redis一次请求需要 连接应答处理器,命令请求处理器,命令回复处理,而这个io多路复制机制就是会同时监控多个请求,同时把每个请求标记上状态放入队列,然后在调用时直接放松给处理器就可以了。这样就省去了判断请求到达了哪一步,去识别该交于那个处理器这个过程。

为什么Redis 单线程却能支撑高并发

              3:如果是多线程,应该需要记录上一线程数据的内存,而每次线程的变换都需要去处理这块内存,肯定要话费一定时间。