Netty核心之Channel源码学习
Channel服务端启动核心路径总结
1.newChannel()创建Channel对象
2.Init()初始化预设参数
3.Register()注册到Selector
4.doBind()绑定端口
反射创建服务端Channel
1.newSocket()[通过jdk来创建底层jdk channel]
2.NioServerSocketChannelCobfig()[tcp参数配置类]
3.AbstractNioChannel()
4.configureBlocking(false)[阻塞模式]
5.AbstractChannel()[创建id,unsafe,pipeline]
//provider获得一个Selector
//把Server注册到Selector
//显示的设置一个configureBlocking(false)
//调用原生的bind()
//注册一个空事件
NioServerSocketChannel
ServerSocketChannel
attr(NioServerSocketChannel)
API是原生BIO设计的,有是基于系统网卡
初始化创建服务端Channel
1.Init()[初始化入口]
2.set ChannelOptions和ChannelAttrs
3.Set ChildOptions和ChildAttrs
4.Config handler[配置服务端pipeline]
5.add ServerBootstrapAcceptor[添加连接器]
注册Selector
1.AbstractChannel.register(channel)[入口]
2.this.eventLoop=eventLoop[绑定线程]
3.Resgiter()[注册]
4.doRegister()[调用JDK底层完成注册]
5.invokerHandlerAddedIfNeeded()
6.fireChannelRegistered[传播事件]