作为Netty的服务端Channel,即NioServerSocketChannel,它的职责就是负责监听ACCEPT事件,当有客户端连接到服务端时,NioServerSocketChannel负责读取这个ACCEPT请求.
既然作为一个Channel,都是支持读和写操作的.那么这个 NioServerSocketChannel是不支持写操作的,当你想通过这个NioServerSocketChannel向外部写数据的时候,会在Netty内部抛出一个异常,Netty也会捕获这个异常,并不会把这个异常抛出给程序.
代码语言:javascript复制@Override
public void channelActive(ChannelHandlerContext ctx) throws Exception {
ctx.writeAndFlush("this is test1");
super.channelActive(ctx);
}
以上代码,当NioServerSocketChannel完成端口绑定之后,会回调channelActive,我们在此方法中调用writeAndFlush方法,向外部写数据,当然此时并没有任何外部的连接,但是也不影响我们向外部写数据. 最终这个写操作会调用到HeadContext中的write方法
代码语言:javascript复制@Override
public void write(ChannelHandlerContext ctx, Object msg, ChannelPromise promise) {
unsafe.write(msg, promise);
}
继续调用到unsafe.write方法
而NioServerSocketChanenl重写了filterOutboundMessage方法
直接抛出异常,不允许写操作.