redis io多线程
redis单线程是指logic在单线程中执行。

redis io多线程指read、decode、encode、write在io线程池中处理。

开启多线程的时候,同一个连接的命令还是按顺序处理的吗?
对于多线程,每一个线程都有一个任务队列,redis做了负载均衡,把任务平均分配到每一个线程对应的队列,这里并没有考虑任务是否是同一个连接来的;对于reactor,使用的是request-reply的模式,read后,会将epoll的状态设置为writable,write后,再将状态设置为readable,从io检测层面保证了命令处理的顺序性,不管是否开启多线程。

# io-threads 4
# write默认走io线程,因为write需要encode的数据比较大。
# io-threads-do-reads no
协议解析,io读写操作,都是在networking.c


线程怎么调度?
通过加互斥锁的方式。


1100

被折叠的 条评论
为什么被折叠?



