再一次重写dubbo-rpc-thrift

前2天把dubbo-rpc-thrift重写了下,老大看了后说,这个还可以再简化,把不要的东西去掉,然后我又重写了下。

这次修改的地方设计到这些个方面:

1.抛弃dubbo里的Request,Response,Codec,Invocation。会话域用Netty的ChannelBuffer,里面装thrift协议的请求和响应的Frame。

2.重写Transportor,用Netty的LengthFieldPrepender的加头Length,用LengthFieldBasedFrameDecoder作decoder解析Frame,然后直接用它的handler。

3.添加HeaderExchangeHandler,分server端和client端,因为去掉Request和Response了,received方法无法区分side,所以要写2个Handler。在HeaderExchangechannel的send里,直接序列化message为ChannelBuffer,发送出去,然后返回重写的Future。

4.重写DefaultFuture,添加字段serviceName,methodName,在Future.Received()后,解析响应的Frame,有异常直接抛异常,没异常直接返回结果。

等稳定后,就放代码到GitHub上
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值