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
线程怎么调度?
通过加互斥锁的方式。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)