博客
关于我
网络编程实战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/

你可能感兴趣的文章
php mysql procedure获取多个结果集
查看>>
php mysql query 行数,PHP和MySQL:返回的行数
查看>>
PHP mysql_real_escape_string() 函数防SQL注入
查看>>
php mysql优化方法_MySQL优化常用方法
查看>>
PHP OAuth 2.0 Server
查看>>
php odbc驱动,php常用ODBC函数集(详细)
查看>>
php openssl aes ecb,php openssl_encrypt AES-128-ECB iOS
查看>>
php paypal rest api,PayPal REST API指定网络配置文件PHP
查看>>
php pcntl 多进程学习
查看>>
PHP pcntl_fork不能在web服务器中使用的变通方法
查看>>
php private ,public protected三者的区别
查看>>
php PSR规范
查看>>
php rand() 重复,array_rand()函数从另外一个数组中随机取得的一定数量的数组的元素是否会重复?...
查看>>
php redis pub/sub(Publish/Subscribe,发布/订阅的信息系统)之基本使用
查看>>
php redis 集群扩展类文件
查看>>
php redis(2)
查看>>
PHP Redis分布式锁
查看>>
php session超时时间_php怎么设置session超时时间
查看>>
PHP SOAP模块的使用方法:NON-WSDL模式
查看>>
PHP Socket实现websocket(三)Stream函数
查看>>