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

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

使用多线程的原因

单一的reactor线程承担双重任务:既要处理客户端连接的建立,又要处理I/O操作。这种做法让线程忙不过来,导致客户端连接成功率有所下降。此外,随着硬件技术的进步,多核多线程的CPU逐渐普及,单一的reactor线程难以充分发挥CPU资源的潜力。

主-从reactor模式的思想

主反应堆线程的职责是仅负责分发Acceptor连接建立任务。对于已连接的套接字事件,交给sub-reactor线程进行处理。这种设计允许sub-reactor的数量根据CPU的核数灵活配置,从而更好地利用多核资源。

主-从reactor+worker threads模式的优化

与主-从reactor模式相比,其核心思想是将业务逻辑(包括解码、计算和编码)与I/O事件分离。sub-reactor线程负责I/O事件的分发,而业务逻辑则交给线程池进行处理。这种设计进一步解耦了I/O处理和业务逻辑处理,使得系统能够更好地利用多CPU资源,提升整体性能。

这种模式的优势在于能够充分发挥多核多线程的优势,优化了I/O处理和业务逻辑执行的资源分配,从而显著提升了系统的吞吐量和效率。

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

你可能感兴趣的文章
Openlayers实战:绘制图形,导出geojson文件
查看>>
Openlayers实战:绘制图形,导出KML文件
查看>>
Openlayers实战:绘制多边形,导出CSV文件
查看>>
Openlayers实战:绘制带箭头的线
查看>>
Openlayers实战:绘制点、线、圆、多边形
查看>>
Openlayers实战:绘制矩形,正方形,正六边形
查看>>
Openlayers实战:自定义放大缩小,显示zoom等级
查看>>
Openlayers实战:自定义版权属性信息
查看>>
Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
查看>>
Openlayers实战:选择feature,列表滑动,定位到相应的列表位置
查看>>
Openlayers实战:非4326,3857的投影
查看>>
Openlayers高级交互(1/20): 控制功能综合展示(版权、坐标显示、放缩、比例尺、测量等)
查看>>
Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
查看>>
Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
查看>>
Openlayers高级交互(12/20):利用高德逆地理编码,点击位置,显示坐标和地址
查看>>
Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
查看>>
Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
查看>>
Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
查看>>
Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
查看>>
Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
查看>>