1、Redis的高并发和快速原因
1.redis是基于内存的,内存的读写速度非常快;
2.redis是单线程的,省去了很多上下文切换线程的时间;
3.redis使用I/O多路复用技术,可以处理并发的连接。(客户端的连接不占用线程资源,只有当命令成功发送的时候,才会进入单线程,然后依次执行)
解释:多路:多个socket、多个客户端、多个黑窗口
复用:复用那一个线程
2、为什么Redis是单线程的
1.官方答案
因为Redis是基于内存的操作,CPU不是Redis的瓶颈,Redis的瓶颈最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且CPU不会成为瓶颈,那就顺理成章地采用单线程的方案了。
3、 Redis单线程的优劣势
1)单进程单线程优势
代码更清晰,处理逻辑更简单
2)单进程单线程弊端
无法发挥多核CPU性能,不过可以通过在单机开多个Redis实例来完善。