当前位置: 首页 > news >正文

长沙平面设计公司都有哪些四川seo推广公司

长沙平面设计公司都有哪些,四川seo推广公司,中国站长站,网站能否做二维码事实上#xff0c;Reactor 模式也叫Dispatcher模式#xff0c;即I/O 多路复⽤监听事件#xff0c;收到事件后#xff0c;根据事件类型分配#xff08;Dispatch#xff09;给某个进程/线程。Reactor 模式也是一种非阻塞同步网络模式。 Reactor 模式主要由 Reactor部分和处…事实上Reactor 模式也叫Dispatcher模式即I/O 多路复⽤监听事件收到事件后根据事件类型分配Dispatch给某个进程/线程。Reactor 模式也是一种非阻塞同步网络模式。 Reactor 模式主要由 Reactor部分和处理事件部分这两个核⼼部分组成它俩负责的事情如下 Reactor部分负责监听和分发事件事件类型包含连接事件、读写事件处理事件部分负责处理事件如 read - 业务逻辑 - send Reactor 模式是灵活多变的可以应对不同的业务场景灵活在于 Reactor 的数量可以只有⼀个也可以有多个处理事件部分可以是单个进程/线程也可以是多个进程/线程 单Reactor单进程/线程 方案示意图 其中 Reactor对象用于监听所有的套接字以及按事件类型分发给不同对象。Acceptor对象用于listen套接字事件发生后的建立新连接。Hander对象用于普通套接字事件发生后处理对应的业务。 具体思想我们可以理解为 Reactor 对象通过IO 多路复⽤接⼝监听事件收到事件后通过 dispatch 进⾏分发具体分发给 Acceptor 对象还是 Handler 对象还要看收到的事件类型如果是连接建⽴的事件则交由 Acceptor 对象进⾏处理Acceptor 对象会通过 accept⽅法 获取连接并创建⼀个 Handler 对象来处理后续的响应事件如果不是连接建⽴事件 则交由当前连接对应的 Handler 对象来进⾏响应Handler 对象通过 read - 业务处理 - send 的流程来完成完整的业务流程。 该方案的缺点 因为是单进程所以无法充分利用多核CPU性能。Hander对象在处理业务的时候整个进程是无法处理其他连接的事件的如果业务处理耗时比较长的话会造成响应的延迟因此适用于业务处理快速的场景比如Redis。 单Reactor多进程/线程 方案示意图 相比与单进程 Hander对象不再负责业务的处理逻辑只负责数据的接收和发送。添加了线程池方案将对应的要处理的业务逻辑交由线程池中的线程处理。 方案思想 Reactor 对象通过多路复用监听事件收到事件后通过 dispatch 进⾏分发具体分发给 Acceptor 对象还是 Handler 对象还要看收到的事件类型如果是连接建⽴的事件则交由 Acceptor 对象进⾏处理Acceptor 对象会通过 accept⽅法 获取连接并创建⼀个 Handler 对象来处理后续的响应事件如果不是连接建⽴事件 则交由当前连接对应的 Handler 对象来进⾏响应Handler 对象不再负责业务处理只负责数据的接收和发送Handler 对象通过 read 读取到数据后会将数据发给线程池中的空闲⼦线程⾥的 Processor 对象进⾏业务处理⼦线程⾥的 Processor 对象就进⾏业务处理处理完后将结果发给主线程中的 Handler对象接着由 Handler 通过 send ⽅法将响应结果发送给 client 多线程的方案优势在于能够充分利用多核CPU的性能但是引入了多线程自然也带来了多线程资源竞争的问题。 多Reactor多进程/线程 单 Reactor的模式还有个问题因为⼀个 Reactor 对象承担所有事件的监听和分发⽽且只在主线程中运⾏在⾯对瞬间⾼并发的场景时容易成为性能的瓶颈的地⽅ 那我们此时会想到什么不错再引入Reactor 示意图 相比于单Reactor的改进 通过将需要监听的套接字分布在多个Reactor上从而减轻主线程主Reactor的负担。主线程的Reactor对象只负责监听listen套接字并建立新连接。 方案思想 主线程中的 MainReactor 对象通过 select 监控连接建⽴事件收到事件后通过 Acceptor对象中的 accept 获取连接将新的连接分配给某个子线程⼦线程中的 SubReactor 对象将 MainReactor 对象分配的连接加⼊ select 继续进⾏监听并创建⼀个 Handler ⽤于处理连接的响应事件如果有新的事件发⽣时SubReactor 对象会调⽤当前连接对应的 Handler 对象来进⾏响应Handler 对象通过 read - 业务处理 - send 的流程来完成完整的业务流程 ⭐️⭐️⭐️优点 主线程和⼦线程分⼯明确主线程只负责接收新连接并将新连接交给子线程⼦线程负责完成该连接后续的监听和业务处理。主线程和⼦线程的交互很简单主线程只需要把新连接传给⼦线程⼦线程⽆须返回数据直接就可以在⼦线程将处理结果发送给客户端。
http://www.tj-hxxt.cn/news/225562.html

相关文章:

  • 网站开发通用流程图公司做网站需要哪些手续
  • 廊坊网站推广排名品牌网站建设优化公司排名
  • 在线购物网站建设流程图深圳网站建设公司哪家
  • 顺德o2o网站建设免费高清视频素材app哪里找
  • 到哪个网站做任务如何注册公司公众号
  • discuz和wordpress哪个好南通网站建设优化
  • 网站做淘客网站设计的文案
  • 一站式做网站平台不用囤货
  • 超炫网站模板网站网页设计html
  • 汉中微信网站建设开发淮安网站建设制作
  • 关于华大18年专注seo服务网站制作应用开发京东店铺购买平台
  • 怎么查看网站的友情链接辽宁建设工程信息网场内业绩什么意思
  • 张家界网站建设app建德网站制作公司
  • 济南网站建设公司选济南网络佛山微网站推广哪家专业
  • 网站织梦模板jsp 网站开发教程
  • 快速搭建网站的工具wordpress主题的作用
  • 千博企业网站管理系统旗舰版装修工人找活平台
  • 自己做的网站可以卖简述网站开发基本流程图
  • pc端手机网站 viewport 自适应好玩的网页游戏排行榜电脑
  • 什么软件是做网站的wordpress首页不显示全文
  • 莱芜市网站建设设计品牌设计logo vi设计
  • 智能网站建设设计引流推广
  • 一个网站有多个域名大连免费营销型建站网络推广
  • 门户网站的优点seo关键词找29火星软件
  • 讯展网站优化推广吴川房产网
  • 网站主页特效欣赏一个网站备案两个域名吗
  • 网站建设分类wordpress缓存方法 张戈
  • 哪个网站可以做计算机二级的题wordpress 媒体文件库
  • 在哪个网站做ppt模板赚钱优化营商环境指什么
  • 专门做黄漫的网站建立一个购物网站平台费用