+
95
-

redis 属于单线程还是多线程?

请问redis 属于单线程还是多线程?

网友回复

+
15
-

redis是多线程也是多线程,原因如下:

在Redis4.0之前,Redis是单线程运行的,但是单线程并不代表效率就低,像Nginx、Nodejs也是单线程程序,但是它们的效率并不低。

原因就是Redis是基于内存操作的,它的瓶颈在于机器的内存、网络带宽,而不是CPU,在你CPU还没达到瓶颈时你的内存可能就先满了、或者带宽达到瓶颈了。因此CPU不是主要原因,那么自然就采用单线程了,况且使用多线程比较麻烦。

但是在Redis 4.0的时候,已经开始支持多线程了,Redis在4.0以及之后的版本中引入了惰性删除(也叫异步删除),意思就是我们可以使用异步的方式对Redis中的数据进行删除操作了,例如:unlink key、flushdb async、flushall async,举个例子:

127.0.0.1:6379> set name han...

点击查看剩余70%

我知道答案,我要回答