请问redis 属于单线程还是多线程?
网友回复
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%