DangerWind-RPC-framework---八、Netty网络通信
创始人
2025-01-07 05:35:52
0

       客户端与服务端之间发送数据需要进行网络通信,而Netty恰好是一款出色的网络通信框架,Netty底层实现依赖于NIO,其工作线程组EventLoopGroup中的每一个EventLoop可以理解为一个线程,与NIO类似,EventLoopGroup的工作也是基于事件响应的,可以理解为bossEventLoop负责监听连接事件,并建立连接,众多workEventLoop监听读事件,在channel可读时读入数据并进行处理。

       在写出与读入数据的过程中,数据会经过流水线上的一道道Handler来处理,首先以客户端为例:

   public NettyRpcClient() {         // initialize resources such as EventLoopGroup, Bootstrap         eventLoopGroup = new NioEventLoopGroup();         bootstrap = new Bootstrap();         bootstrap.group(eventLoopGroup)                 .channel(NioSocketChannel.class)                 .handler(new LoggingHandler(LogLevel.INFO))                 //  The timeout period of the connection.                 //  If this time is exceeded or the connection cannot be established, the connection fails.                 .option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000)                 .handler(new ChannelInitializer() {                     @Override                     protected void initChannel(SocketChannel ch) {                         ChannelPipeline p = ch.pipeline();                         // If no data is sent to the server within 15 seconds, a heartbeat request is sent                         p.addLast(new IdleStateHandler(0, 5, 0, TimeUnit.SECONDS));                         p.addLast(new RpcMessageEncoder());                         p.addLast(new RpcMessageDecoder());                         p.addLast(new NettyRpcClientHandler());                     }                 });         this.serviceDiscovery = ExtensionLoader.getExtensionLoader(ServiceDiscovery.class).getExtension(ServiceDiscoveryEnum.ZK.getName());         this.unprocessedRequests = SingletonFactory.getInstance(UnprocessedRequests.class);         this.channelProvider = SingletonFactory.getInstance(ChannelProvider.class);     }

        当数据发出时,会被经过的一个个ChannelOutboundHandler(简称out)依次处理,而不会被ChannelInboundHandler(简称in)处理, RpcMessageEncoder对应的是out,因为写出时才会需要编码,RpcMessageDecoder和NettyRpcClientHandler对应的是in,因为读取服务端数据时才需要解码以及处理响应数据。

        服务端也是类似:

   try {             ServerBootstrap b = new ServerBootstrap();             b.group(bossGroup, workerGroup)                     .channel(NioServerSocketChannel.class)                     // TCP默认开启了 Nagle 算法,该算法的作用是尽可能的发送大数据快,减少网络传输。TCP_NODELAY 参数的作用就是控制是否启用 Nagle 算法。                     .childOption(ChannelOption.TCP_NODELAY, true)                     // 是否开启 TCP 底层心跳机制                     .childOption(ChannelOption.SO_KEEPALIVE, true)                     //表示系统用于临时存放已完成三次握手的请求的队列的最大长度,如果连接建立频繁,服务器处理创建新连接较慢,可以适当调大这个参数                     .option(ChannelOption.SO_BACKLOG, 128)                     .handler(new LoggingHandler(LogLevel.INFO))                     // 当客户端第一次进行请求的时候才会进行初始化                     .childHandler(new ChannelInitializer() {                         @Override                         protected void initChannel(SocketChannel ch) {                             // 30 秒之内没有收到客户端请求的话就关闭连接                             ChannelPipeline p = ch.pipeline();                             p.addLast(new IdleStateHandler(30, 0, 0, TimeUnit.SECONDS));                             p.addLast(new RpcMessageEncoder());                             p.addLast(new RpcMessageDecoder());                             p.addLast(serviceHandlerGroup, new NettyRpcServerHandler());                         }                     });              // 绑定端口,同步等待绑定成功             ChannelFuture f = b.bind(host, PORT).sync();             // 等待服务端监听端口关闭             f.channel().closeFuture().sync();         } catch (InterruptedException e) {             log.error("occur exception when start server:", e);         } finally {             log.error("shutdown bossGroup and workerGroup");             bossGroup.shutdownGracefully();             workerGroup.shutdownGracefully();             serviceHandlerGroup.shutdownGracefully();         }

       服务端也使用RpcMessageEncoder和RpcMessageDecoder来进行编解码,因为整个框架的编解码需要使用同一套规则。NettyRpcServerHandler自然对应的是in,因为需要在接收读取数据时进行处理,服务端具体通过反射调用执行方法获取执行结果的过程就发生在这里。

       除此之外,网络通信还需要解决粘包半包的问题,也需要指定一套通信时的规则并可以被双方感知。因此需要自定义rpc协议,这也是rpc与http的区别之一。这里给出本RPC框架自定义的数据格式:

       收发数据的双方均按此格式进行数据的封装解析,就可以避免粘包半包问题的出现,并且也明确了数据的解析方式,便于接收方进行数据的解析与后续的处理。

相关内容

热门资讯

第九分钟辅助!天天爱柳州辅助器... 天天爱柳州辅助器是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微...
热门推荐!微信小程序蜀山辅助器... 热门推荐!微信小程序蜀山辅助器免费下载(辅助)外挂辅助开挂插件(有挂秘诀)-哔哩哔哩;最新版2026...
第4分钟普及!奇迹陕西辅助器(... 第4分钟普及!奇迹陕西辅助器(透视)原来真的是有挂脚本(推荐开挂软件);奇迹陕西辅助器免费下载原版,...
第八分钟讲解!越乡游金花辅助,... 第八分钟讲解!越乡游金花辅助,九酷众游辅助,细节方法(有挂实锤)-哔哩哔哩1、下载安装好越乡游金花辅...
透视软件!浙江宝宝游戏辅助工具... 透视软件!浙江宝宝游戏辅助工具(辅助)外挂开挂辅助插件(了解有挂)-哔哩哔哩;是一款可以让一直输的玩...
第5分钟发现!桃乐甘肃麻将下载... 《第5分钟发现!桃乐甘肃麻将下载辅助器(辅助)原来有挂软件(必看开挂工具)》 桃乐甘肃麻将下载辅助器...
第8分钟了解!河洛刚次辅助,温... 第8分钟了解!河洛刚次辅助,温州茶苑辅助软件,详细教程(有挂攻略)-哔哩哔哩;无需打开直接搜索加薇1...
热点讨论!新二号辅助软件下载(... 热点讨论!新二号辅助软件下载(辅助)外挂辅助开挂软件(有挂教程)-哔哩哔哩;是一款可以让一直输的玩家...
8分钟解说!网易亲友圈辅助(开... 8分钟解说!网易亲友圈辅助(开挂)原来有挂平台(必看开挂安装);小薇(透视辅助)致您一封信;亲爱网易...
第5分钟开挂!如何在哈灵上辅助... 第5分钟开挂!如何在哈灵上辅助,决战卡五星辅助看牌器,解说技巧(有挂方略)-哔哩哔哩 了解更多开挂安...