1. LCN简介
LCN是一个分布式事务框架,底层的网络框架使用的就是netty。LCN分为客户端(TC)和服务器端(TM),本文不会对LCN做过多的介绍,只是从底层的网络框架来说明netty在实际项目中的应用。TM作为一个服务端,需要单独启动,而LCN的TM是一个springboot项目,环境搭建和启动过程和一般的springboot项目类似。
LCN的TM和TC在springboot启动过程中,利用spring的applicationRunner实现netty服务端的启动和客户端连接服务器,具体流程如下所示:
2. netty在LCN的TM中的应用
NettyRpcServerInitializer的init方法的源码如下:
NettyRpcServerChannelInitializer类的源码如下:
在ServerBootstrap的childHandler中,添加了很多的handler:
- LengthFieldPrepender:基于变长消息的编码器
- LengthFieldBasedFrameDecoder:基于变长消息的解码器
- IdleStateHandler:基于心跳检查的处理器
- ObjectSerializerEncoder:自定义对象序列化编码器
- ObjectSerializerDecoder:自定义对象序列化解码器
- RpcCmdDecoder:自定义的指令解码器
- RpcCmdEncoder:自定义的指令编码器
- SocketManagerInitHandler:自定义心跳检查处理器
- RpcAnswerHandler:自定义具体业务处理器
经过NettyRpcServerInitializer类的init方法的执行,TM启动完毕,等待客户端TC的连接和数据的传输。
3.netty在LCN的TC中的应用
NettyRpcClientInitializer的init方法如下所示:
NettyRpcClientChannelInitializer的源码如下:
客户端的handler如下:
- LengthFieldPrepender:基于变长消息的编码器
- LengthFieldBasedFrameDecoder:基于变长消息的解码器
- ObjectSerializerEncoder:自定义对象序列化编码器
- ObjectSerializerDecoder:自定义对象序列化解码器
- RpcCmdDecoder:自定义的指令解码器
- RpcCmdEncoder:自定义的指令编码器
- SocketManagerInitHandler:自定义心跳检查处理器
- RpcAnswerHandler:自定义具体业务处理器
- NettyClientRetryHandler:自定义客户端重连处理器
经过NettyRpcClientInitializer的init方法的执行,TC就建立了和TM的连接,以后就可以通过这个常连接进行数据的交互。