博客
关于我
网络编程实战28 多线程使用poll处理连接I/O事件(主从reactor)
阅读量:316 次
发布时间:2019-03-03

本文共 345 字,大约阅读时间需要 1 分钟。

使用多线程的原因

●单reactor线程既分发连接建立,又分发I/O,忙不过来,会使得客户端连接成功率偏低。

●新的硬件技术不断发展,多核多路CPU已经得到极大应用,单reactor不能充分利用CPU资源

主-从reactor模式

思想:

 主反应堆线程只负责分发Acceptor连接建立,已连接套接字上的事件交给sub-reactor负责分发。其中sub-reactor的数量可以根据CPU的核数来灵活设置。
在这里插入图片描述

主-从reactor+worker threads模式

思想:

 与主-从reactor模式的区别在于,将业务逻辑(decode+compute+encode)和I/O分发解耦,sub-reactor负责I/O事件,业务逻辑交给线程池处理。可以进一步利用多CPU特效,提高效率。

在这里插入图片描述

转载地址:http://rfdq.baihongyu.com/

你可能感兴趣的文章
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql where中如何判断不为空
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>