Netty 的 Channel 和 EventLoop 之间的关系是什么?

 作者简介:大家好,我是码炫码哥,前中兴通讯、美团架构师,现任某互联网公司CTO,兼职码炫课堂主讲源码系列专题


代表作:《jdk源码&多线程&高并发》,《深入tomcat源码解析》,《深入netty源码解析》,《深入dubbo源码解析》,《深入springboot源码解析》,《深入spring源码解析》,《深入redis源码解析》等


联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬。码炫课堂的个人空间-码炫码哥个人主页-面试,源码等

释放21集全网最深ConcurrentHashMap的vip视频,复现每一行源码

回答

在 Netty 中,一个 Channel 代表一个连接,而 EventLoop 则是一个用于处理 I/O 操作的事件循环。当客户端连接服务端后,服务端会为它创建一个 Channel,该 Channel 代表了与该客户端的连接。同时,也会将该客户端绑定到一个 EventLoop 上,在其生命周期内,该 Channel 所有产生的 I/O 事件都由与之绑定的 EventLoop 来处理。所以它们两者的关系是:

  1. 每个 Channel 都会被分配到一个 EventLoop 与之绑定。一旦该 Channel 被分配给一个 EventLoop 后,它将在其整个生命周期内保持这个绑定关系。
  2. 同一个 Channel 的所有 I/O 操作和事件都将由与之绑定的 EventLoop 来处理。这样可以避免多线程并发问题,无需担心同一个 Channel 的操作之间的同步问题。
  3. 一个 EventLoop 可以被分配给多个 Channel,因此它可以处理多个连接的 I/O 操作。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值