美文网首页Java 杂谈Netty程序员
Netty源码阅读入门实战(五)-新连接检测

Netty源码阅读入门实战(五)-新连接检测

作者: 紫霞等了至尊宝五百年 | 来源:发表于2018-07-31 00:42 被阅读81次

1 检测新连接

打断点

telnet 此机地址,引起连接建立


执行到此,进入查看


以上即对应 read 方法




继续返回原先位置

2 NioSocketChannel的创建









禁止小包组成大包再发送方法




看看这个静态变量




由于 netty 常部署在服务端,所以默认启动 TCP无延时


3 Channel的分类



先看看最顶层的框架 Channel



网络 Socket 读写绑定的一种抽象

作为骨架,保存了很多基础且重要的信息


使用选择器监听 IO 事件的一个抽象类
保存了 JDK 底层的一个 Channel


开启非阻塞模式



回到了抽象类,即保存了一个ACCEPT 事件
看过服务 Channel 后,再看看客户端 Channel





客户端与服务端的 Channel 在 unsafe 类上也不同
客户端 Chanel




服务端 Chanel

用于某种 Chanel 的读写情况
主要负责读事件
读字节
不同端配置项也不同

4 新连接NioEventLoop的分配和selector注册





即为此处调用




回调之后,最终都会删除自身











回去看看 register 方法







5 NioSocketChannel读事件的注册












可以开始接收数据了




回顾一下创建


6 新连接接入总结



boss线程的第一个过程轮训处Accept事件,然后boss线程第二个过程通过jdk底层的channel的accept方法创建该连接。



新连接NioEventLoop的分配和selector注册可以回答。boss线程调用chooser的next方法,拿到一个NioEventLoop,然后将这条连接注册到NioEventLoop的selector上面。

相关文章

网友评论

    本文标题:Netty源码阅读入门实战(五)-新连接检测

    本文链接:https://www.haomeiwen.com/subject/spkvmftx.html