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

过程简析

服务端
客户端



相关推荐
宇木灵2 小时前
C语言基础-十、文件操作
c语言·开发语言·学习
QQ24391975 小时前
语言在线考试与学习交流网页平台信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·spring boot·sql·学习·java-ee
The_Uniform_C@t27 小时前
论文浅读(第三期)|摘自《UAV Resilience Against Stealthy Attacks》(第一节)
网络·物联网·学习·网络安全
青衫码上行7 小时前
高频 SQL 50题(基础版)| 查询 + 连接
数据库·sql·学习·mysql
宇木灵8 小时前
C语言基础学习-X0前置
c语言·开发语言·学习
希望之晨8 小时前
c++ 11 学习 override
开发语言·c++·学习
学编程的闹钟8 小时前
E语言组件开发全攻略
学习
winfreedoms8 小时前
Puppypi——树莓派5主板学习笔记
笔记·学习
gjf05_058 小时前
人该怎样活着呢?版本69.2
学习
蒸蒸yyyyzwd9 小时前
cpp八股学习笔记
笔记·学习