Channel, Event 和 I/O

Netty 是一个非阻塞、事件驱动的网络框架
Netty 实际上是使用 Threads(多线程)处理 I/O 事件;对于多线程的开发我们经常会关注的问题可能就是同步的问题(也即是得出的结果是正确的)。这样就会降低了程序的性能。
Netty 的设计保证程序处理事件不会有同步。

Channel, Event 和 I/O_第1张图片
不需要在 Channel 之间共享 ChannelHandler 实例

该图显示,一个 EventLoopGroup 具有一个或多个 EventLoop。想象 EventLoop 作为一个 Thread 给 Channel 执行工作。 (事实上,一个 EventLoop 是势必为它的生命周期一个线程。)
当创建一个 Channel,Netty 通过 一个单独的 EventLoop 实例来注册该 Channel(并同样是一个单独的 Thread)的通道的使用寿命。这就是为什么你的应用程序不需要同步 Netty 的 I/O操作;所有 Channel 的 I/O 始终用相同的线程来执行。(这样似乎有点同步串行的操作【在线程以内】)

你可能感兴趣的:(Channel, Event 和 I/O)