Redis是单线程还是多线程?
知乎上的一篇文章写得比较好,记录一下 Redis是单线程还是多线程?
- 目前所说的Redis单线程,指的是"其网络IO和键值对读写是由一个线程完成的",也就是说,Redis中只有网络请求模块和数据操作模块是单线程的。而其他的如持久化存储模块、集群支撑模块等是多线程的。
在提升I/O利用率这个方面上,Redis并没有采用多线程技术,而是选择了I/O多路复用技术。 - Redis 6.0中的多线程,也只是针对处理网络请求过程采用了多线程,而数据的读写命令,仍然是单线程处理的。
Redis 6.0 只有在网络请求的接收和解析,以及请求后的数据通过网络返回时,使用了多线程。而数据读写操作还是由单线程来完成的,所以,这样就不会出现并发问题了。