netty学习07-netty在LCN分布式事务框架中的应用

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的连接,以后就可以通过这个常连接进行数据的交互。

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值