netty-daxin-3(rpc远程调用)

文章目录

nettyRpc

ObjectEncoder 与 ObjectDecoder

  • ObjectEncoder继承自MessageToByteEncoder<Serializable>,它内部使用ByteBufOutputStream包装ByteBuf对象,然后使用CompactObjectOutputStream包装ByteBufOutputStream,也即:CompactObjectOutputStream--->ByteBufOutputStream--->ByteBuf,然后使用CompactObjectOutputStream将java对象写到ByteBuf中,并且写的过程中,是先写4个字节的占位符,它代表消息内容的长度,等写完了整个java对象的流之后,再把长度写到4个字节的占位符上。
  • ObjectDecoder继承自LengthFieldBasedFrameDecoder,显然,与它对应的编码器写消息的时候,就是按照长度字段来写的,因此解码须继承LengthFieldBasedFrameDecoder,然后拿到对象的字节流后,CompactObjectInputStream--->ByteBufInputStream--->ByteBuf

jdk动态代理回顾

Rpc调用

有几个重要的点:

  1. 最好不要在eventLoop处理解码的ChannelHandler上处理业务,因为eventLoop内部只有1个线程在处理多个channel,如果处理业务的逻辑放在handler里面,相当于其它的channel就会受影响
  2. netty的调用都是异步的,我们需要在客户端发出rpc请求后,阻塞当前rpc调用的线程,然后在得到服务端的响应之后,再去唤醒当前调用rpc的线程。这需要对AQS、ReentrantLock、Condition内部的锁并发等待唤醒了解。

过程简析

服务端
客户端



相关推荐
圆弧YH2 分钟前
排版基本操作
学习
啊阿狸不会拉杆5 分钟前
《计算机视觉:模型、学习和推理》第 19 章-时序模型
人工智能·python·学习·机器学习·计算机视觉·时序模型
Errorbot7 分钟前
GPS学习(二)使用树莓派5和GPS PPS 实现微秒级精度的时间同步
学习·ubuntu·gps
嘉琪00113 分钟前
Day1 完整学习包(var/let/const + 作用域)——2026 0310
前端·javascript·学习
·中年程序渣·16 分钟前
Spring AI Alibaba入门学习(三)
java·学习·spring
xx240622 分钟前
RN学习笔记
笔记·学习
Agno ni23 分钟前
RAG-anthing学习笔记
笔记·学习
墨澜逸客24 分钟前
《十善积德·因果录》-融古训之精粹,以此劝世修身
学习·其他·百度·学习方法
youyoulg26 分钟前
有监督学习中的分类方法
学习·分类·数据挖掘
babe小鑫28 分钟前
2026大专商务英语专业学习数据分析的价值分析
学习·数据挖掘·数据分析