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内部的锁并发等待唤醒了解。

过程简析

服务端
客户端



相关推荐
PNP Robotics2 分钟前
PNP机器人亮相南京学术论坛,分享具身智能多模态数据采集前沿成果
人工智能·深度学习·学习·机器学习·virtualenv
毕小宝4 分钟前
AI 编程应用:实现 npm CLI 工具 scp-upload
学习
清钟沁桐5 分钟前
mlir 编译器学习笔记之十 -- 数据类型
笔记·学习·mlir
red_redemption7 分钟前
自由学习记录(190)
学习
Pizza_Lawson11 分钟前
spinningup学习笔记(二)
笔记·学习
吃好睡好便好14 分钟前
在Matlab中绘制饼状图
开发语言·学习·matlab·3d·信息可视化
nashane16 分钟前
HarmonyOS 6学习:外接键盘CapsLock键“失灵”?一招解锁大写输入
学习·华为·计算机外设·harmonyos
清钟沁桐21 分钟前
mlir 编译器学习笔记之九 -- 后端生成
笔记·学习·mlir
叶~小兮24 分钟前
Zabbix 7.0 深度原理与生产进阶运维学习笔记
运维·学习·zabbix
我想我不够好。28 分钟前
2026.5.21 消防监控学习 1.5hours
学习