redis io多线程

redis io多线程,第1张

redis io多线程

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

线程怎么调度?

通过加互斥锁的方式。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5718297.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-18
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存