一.总结
- 纯内存操作
- 核心是基于非阻塞的 IO 多路复用机制
- 单线程反而避免了多线程的频繁上下文切换问题
二.个人理解
- db操作需要操作磁盘,涉及到io所有效率肯定比内存效率低。
- 个人理解就是,redis一次请求需要连接应答处理器,命令请求处理器,命令回复处理,而这个io多路复制机制就是会同时监控多个请求,同时把每个请求标记上状态放入队列,然后在调用时直接放松给处理器就可以了。这样就省去了判断请求到达了哪一步,去识别该交于那个处理器这个过程。
- 如果是多线程,应该需要记录上一线程数据的内存,而每次线程的变换都需要去处理这块内存,肯定要话费一定时间。