netty连接nbiot_RPC 实战与原理 精简版

什么是 RPC?

Remote Procedure Call,远程过程调用。

RPC 有什么作用?屏蔽远程调用、本地调用的区别

隐藏底层网络通信的复杂性,让我们更专注于业务

RPC 步骤

84dabb7e0cbaa7438878d76e68be23a0.png

为什么需要序列化?网络传输必须是「二进制」,调用方的参数都是对象

请求↔二进制消息体

零拷贝

什么是零拷贝?

5a7f109a692179fdeb94d9f056a6a699.png

为什么需要零拷贝?

网卡等操作,只能通过内核操作,应用程序要发送网络数据,需要将数据复制到内核。

如何实现零拷贝?

虚拟内存mmap + write

sendfile

Netty 的零拷贝有何不同?一个请求,可能拆分成多个数据包

数据包的组合在用户空间,解决用户空间内存的拷贝处理问题,CompositeByteBuf

也包括用户空间、内核空间的数据拷贝:Direct Buffers

动态代理实现JDK:只能代理接口

<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值