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

过程简析

服务端
客户端



相关推荐
星幻元宇VR2 分钟前
VR爱国教育学习机|让红色精神在沉浸体验中代代传承
科技·学习·vr·虚拟现实
逆小舟8 分钟前
【SWM320】学习使用UART
单片机·学习·嵌入式软件
果果燕37 分钟前
网络编程-TCP 协议学习笔记
网络·学习·tcp/ip
蒸蒸yyyyzwd39 分钟前
设计模式之美学习笔记
笔记·学习·设计模式
非凡ghost40 分钟前
Smart Launcher安卓版(安卓桌面启动器)
android·windows·学习·音视频·软件需求
智慧化智能化数字化方案1 小时前
向华为学习——解读华为工业与AI融合应用指南【】
人工智能·学习·华为工业与ai融合应用指南
盐水冰1 小时前
【烘焙坊项目】后端搭建(11)- 用户&商家订单板块
java·后端·学习
头疼的程序员1 小时前
计算机网络:自顶向下方法(第七版)第五章 学习分享(一)
学习·计算机网络
zyb11475824331 小时前
集合的学习
开发语言·python·学习
老树临风_1 小时前
ROS2机器人智能小车学习(1)- ROS2 最简安装与配置
学习·机器人·ros2