开发者社区> 问答> 正文

netty EventLoopGroup 问题

已解决

netty 为何server端需要使用两个EventLoopGroup,而client 的只需要一个?还有为何要默认设置为 CPU双倍的线程,是因为默认为IO密集型 所以这么配置吗?

展开
收起
Atom 2020-04-21 10:24:58 960 0
1 条回答
写回答
取消 提交回答
  • 采纳回答

    这里定义了2个NioEventLoopGroup,实际上就是2个线程池,一个是用于监听客户端的连接,一个用户处理网络io,或者执行系统task等,参考链接。 用于接收客户端请求的线程池职责如下: 1)接收客户端tcp请求,初始化Channel参数。 2)将链路状态变更事件通知给ChannelPipeline。 用于处理io操作的Reactor线程池职责如下: 1)异步读取通信端的数据,发送读事件到ChannelPipeline; 2)异步发送消息到通信对端,调用ChannelPipeline的消息发送接口; 3)执行系统调用Task; 4)执行定时任务Task,例如链路空闲状态监测定时任务;
    来源:云原生后端社区

    2020-04-21 10:26:33
    赞同 展开评论 打赏
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载