当前位置: 首页 > 知识库问答 >
问题:

理解Netty内部结构

蓬琦
2023-03-14

根据我对Netty的理解,传入消息传递给eventLoop(只有一个eventLoop,一个线程)。接下来,EventLoop不处理它,而是将其传递给ExecutorService(它在池中保存多个线程)执行。

所有这些都是在NIO的帮助下实现的。EventLoop等待传入消息,并通过选择器、键、通道等传递消息。

我说的对吗?

使用Netty 4

共有1个答案

茹航
2023-03-14

据我所知,Netty使用EvenLoopGroup来处理传入和传出数据以及传入连接。当您开始使用Netty时,这应该不会很有趣,因为数据通过不同的类。当消息入站时,您可以拦截它的第一个接口是解码器(ByteToMessageDecoder),您的加密ByteBuf可用。然后它通过处理程序(ChannelIn⃣Handler)。

 类似资料:
  • 现在,你应该相当了解 Git 在背后都做了些什么工作,并且在一定程度上也知道了 Git 是如何实现的。 本章讨论了很多底层命令,这些命令比我们在本书其余部分学到的高层命令来得更原始,也更简洁。 从底层了解 Git 的工作原理有助于更好地理解 Git 在内部是如何运作的,也方便你能够针对特定的工作流写出自己的工具和脚本。 作为一套内容寻址文件系统,Git 不仅仅是一个版本控制系统,它同时是一个非常强

  • 我的服务器将响应发送到客户端或将消息转发到另一个客户端取决于消息内容。我需要使用8字节的消息:大括号之间的6个加密字节,例如: 其中0x3c表示<符号作为开始帧标记,0x3e表示>符号作为结束帧标记。 所以我得到4字节的有效负载(0x02,0x03,0x04,0x05)。 我已经编写了一个FrameDecoder,但现在我不能决定是否删除大括号字节: 我想写干净的代码,大括号只是框架标记,所以它们

  • 本文向大家介绍java HashMap内部实现原理详解,包括了java HashMap内部实现原理详解的使用技巧和注意事项,需要的朋友参考一下 详解HashMap内部实现原理 内部数据结构 从上面的数据结构定义可以看出,HashMap存元素的是一组键值对的链表,以什么形式存储呢 可以看出,是以数组形式储存,好的,现在我们知道,HashMap是以数组形式存储,每个数组里面是一个键值对,这个键值对还可

  • CInode CInode 包含某一文件的元数据,每个文件都有一个 CInode 。它存储着类似谁拥有这个文件、此文件有多大这样的信息。 CDentry CDentry 用于把索引节点和文件(或目录)名关联到一起。一个 CDentry 最多可链接到一个 CInode (也可以不链接任何 CInode ),一个 CInode 可被多个 CDentry 链接。 CDir CDir 仅存在于目录索引节点

  • 问题内容: 假设我有一个这样的列表: 要获得打印的值及其索引,我可以使用Python的函数,如下所示 现在,当我尝试在A中使用它时,出现了这个错误 所以,我的问题是:在列表理解中使用枚举的正确方法是什么? 问题答案: 尝试这个: 您需要放入一个元组以使列表理解起作用。另外,鉴于 已经 返回一个元组,您可以直接将其返回而无需先拆包: 无论哪种方式,返回的结果都是预期的:

  • 问题内容: 我在header.h内部定义了一个结构,如下所示: 当我用这种结构初始化一个对象时,我可以访问整数/双精度数,但不能访问数组。 如何访问读/写中的值? 问题答案: 最简单的方法是将数组包装在内,然后可以提供额外的方法来满足“可订阅”的要求。 我整理了一个小例子。假定您使用的是C ++,但是从中构造等效的C版本相当简单,它只需要重复一些即可。 首先,具有要包装的C ++头文件和用于包装固