前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >张龙netty学习笔记 P49~P51 零拷贝

张龙netty学习笔记 P49~P51 零拷贝

作者头像
平凡的学生族
发布2019-05-25 09:12:42
3910
发布2019-05-25 09:12:42
举报
文章被收录于专栏:后端技术后端技术

一代目拷贝——四次拷贝

数据流动:

  1. 外设--DMA-->内核--->用户空间
  2. 用户空间--->内核---->外设 第二步的时候,数据写到内核时方法就返回了,之后由操作系统调度,将数据写到外设

二代目拷贝——三次拷贝

数据流动:

  1. 外设--DMA-->内核空间缓存
  2. 内核缓存-->socket缓存
  3. socket缓存-->外设 数据不再需要拷贝至用户控件,但依旧有从内核缓存拷贝至socket缓存的过程。

三代目拷贝——零拷贝

原视频P51 30分钟处

流程如下:

  1. 数据从外设通过DMA读取至内核缓存
  2. 内核缓存将文件描述符(包含了数据在内核缓存的位置,以及长度)发送给socket缓存
  3. protocol engine使用gather的方式
    1. 从socket缓存读取数据的位置与长度
    2. 从内核缓存读取数据

三代目拷贝与二代目拷贝的区别是:

  • 二代目拷贝会把整个数据从内核缓存传到socket缓存
  • 三代目拷贝只把数据的描述信息传到socket缓存(这个数据量是极小的)。之后数据直接从内核缓存传到外设。

所以没有多余的数据拷贝动作,是效率最高的。这正是netty的零拷贝机制。

老师心语

如果能弄明白零拷贝的机制,不管是面试还是与同事的讨论中,都能极大地增加你的逼格。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019.03.20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一代目拷贝——四次拷贝
  • 二代目拷贝——三次拷贝
  • 三代目拷贝——零拷贝
  • 老师心语
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档