Java NIO框架Netty入门:HelloNetty示例

需积分: 10 4 下载量 56 浏览量 更新于2024-07-14 收藏 2.33MB PDF 举报
"Java NIO框架Netty教程的起步示例" 在Java世界里,Netty是一个基于NIO(Non-blocking I/O)的高性能网络应用框架,它为开发者提供了构建服务器和客户端通信的强大工具。Netty广泛应用于分布式系统、游戏服务器、RPC、Web应用等领域,因其高效、稳定和丰富的功能而备受赞誉。本教程将带你逐步了解如何使用Netty来编写一个简单的“HelloNetty”服务端程序。 首先,我们需要了解Netty的基本架构。Netty的核心组件包括`EventLoopGroup`、`ServerBootstrap`、`Channel`和`ChannelHandler`等。`EventLoopGroup`负责线程管理,`ServerBootstrap`是服务器启动配置类,`Channel`是连接的抽象,而`ChannelHandler`用于处理网络事件和数据。 在提供的代码片段中,我们看到以下几个关键点: 1. 创建`ServerBootstrap`: `ServerBootstrap bootstrap = new ServerBootstrap(new NioServerSocketChannelFactory(Executors.newCachedThreadPool(), Executors.newCachedThreadPool()));` 这行代码初始化了一个`ServerBootstrap`实例,并使用`NioServerSocketChannelFactory`来创建基于NIO的服务器通道。两个`ExecutorService`参数分别用于处理I/O事件和应用级任务,这里使用了缓存线程池以提高性能。 2. 设置`ChannelPipelineFactory`: `bootstrap.setPipelineFactory(new ChannelPipelineFactory() { ... });` 这里我们定义了一个自定义的`ChannelPipelineFactory`,用于创建`ChannelPipeline`。`ChannelPipeline`是处理网络事件和数据的链式结构,每一个`ChannelHandler`对应链中的一个节点。 3. 添加`HelloServerHandler`: `return Channels.pipeline(new HelloServerHandler());` 在`ChannelPipelineFactory`的`getPipeline()`方法中,我们添加了一个名为`HelloServerHandler`的自定义处理器。这个处理器会处理来自客户端的所有入站事件,例如连接建立、数据接收等。 4. 绑定监听端口: `bootstrap.bind(new InetSocketAddress(8000));` 最后,我们通过`bind()`方法将服务器绑定到8000端口,等待客户端连接。 `HelloServerHandler`类是自定义的处理器,通常会包含以下操作: - 处理连接建立事件:当一个新的客户端连接建立时,`channelActive()`方法会被调用。 - 处理解析和响应数据:在`channelRead()`方法中,我们可以解析接收到的数据,并发送回应给客户端。 这是一个非常基础的Netty服务器示例,实际应用中,`ChannelPipeline`会包含多个`ChannelHandler`,处理不同类型的事件和数据,例如解码、编码、业务逻辑处理等。Netty的强大在于其灵活的管道模型,可以根据需求自由定制网络通信流程。 通过这个简单的例子,我们可以感受到Netty框架的简洁和强大。深入学习Netty,可以掌握更多高级特性,如零拷贝、异步非阻塞I/O、以及各种编解码器等,这将极大地提升Java网络编程的效率和能力。

2023-07-13 09:15:56,872 WARN org.apache.flink.runtime.dispatcher.DispatcherRestEndpoint [] - Unhandled exception java.io.IOException: Connection reset by peer at sun.nio.ch.FileDispatcherImpl.read0(Native Method) ~[?:1.8.0_372] at sun.nio.ch.SocketDispatcher.read(SocketDispatcher.java:39) ~[?:1.8.0_372] at sun.nio.ch.IOUtil.readIntoNativeBuffer(IOUtil.java:223) ~[?:1.8.0_372] at sun.nio.ch.IOUtil.read(IOUtil.java:192) ~[?:1.8.0_372] at sun.nio.ch.SocketChannelImpl.read(SocketChannelImpl.java:379) ~[?:1.8.0_372] at org.apache.flink.shaded.netty4.io.netty.buffer.PooledByteBuf.setBytes(PooledByteBuf.java:253) ~[flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.buffer.AbstractByteBuf.writeBytes(AbstractByteBuf.java:1132) ~[flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.channel.socket.nio.NioSocketChannel.doReadBytes(NioSocketChannel.java:350) ~[flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:151) [flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:719) [flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:655) [flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:581) [flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:493) [flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:986) [flink-dist-1.15.3.jar:1.15.3] at org.apache.flink.shaded.netty4.io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74) [flink-dist-1.15.3.jar:1.15.3] at java.lang.Thread.run(Thread.java:750) [?:1.8.0_372]

2023-07-14 上传

com.fmall58.wechatsub.business.bizs.UException at com.fmall58.wechatsub.business.service.PubService.isBindWeChatSub(PubService.java:76) at com.fmall58.wechatsub.business.bizs.PubHelper.isBindWeChatSub(PubHelper.java:125) at com.fmall58.wechatsub.business.bizs.PubHelper.execute(PubHelper.java:38) at com.fmall58.wechatsub.server.handlers.ServerHandler.channelRead(ServerHandler.java:103) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:362) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:348) at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:340) at io.netty.handler.codec.MessageToMessageDecoder.channelRead(MessageToMessageDecoder.java:102) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:362) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:348) at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:340) at io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:323) at io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:297) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:362) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:348) at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:340) at io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1434) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:362) at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:348) at io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:965) at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:163) at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:656) at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:591) at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:508) at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:470) at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:909) at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)

2023-06-11 上传
2023-06-12 上传