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


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

一.总结

  1. 纯内存操作
  2. 核心是基于非阻塞的 IO 多路复用机制
  3. 单线程反而避免了多线程的频繁上下文切换问题

二.个人理解

  1. db操作需要操作磁盘,涉及到io所有效率肯定比内存效率低。
  2. 个人理解就是,redis一次请求需要连接应答处理器,命令请求处理器,命令回复处理,而这个io多路复制机制就是会同时监控多个请求,同时把每个请求标记上状态放入队列,然后在调用时直接放松给处理器就可以了。这样就省去了判断请求到达了哪一步,去识别该交于那个处理器这个过程。为什么Redis单线程却能支撑高并发
  3. 如果是多线程,应该需要记录上一线程数据的内存,而每次线程的变换都需要去处理这块内存,肯定要话费一定时间。


上一篇:zabbix自动发现redis端口并监控redis性能


下一篇:关于远程访问tomcat问题的总结