channel消息处理
从SingleThreadEventExecutor#run方法中找到processSelectedKeys方法。
服务端channel(包含客户端channel注册等)
processSelectedKey方法中,服务端对accept事件感兴趣, unsafe.read()方法会走NioMessageUnsafe#read()方法,做两件事,一件是拿到客户端channel后封装成NioSocketChannel加进list集合,另一件是遍历list集合,将每个客户端channel传递到服务端pipeline中,执行客户端channel注册,客户端pipeline的初始化,客户端channel激活等;
1)首先执行doReadMessages方法,其中调用jdk的ServerSocketChannel的accept方法,拿到SocketChannel,再封装成NioSocketChannel,此处执行了NioSocketChannel的两参数构造方法,执行逻辑和服务端channel几乎一致,接着将每个NioSocketChannel加入List集合;
2)接着遍历List集合, 执行pipeline.fireChannelRead(xxx),将每个NioSocketChannel传入到服务端通道,目前服务端通道是HeadContext<——>配置的handler<——>ServerBootstrapAcceptor<——>TailContext;这里fireChannelRead方法主要在ServerBootstrapAcceptor中实现;首尾均未实现。
3)接着进入到Serve