一代目拷贝——四次拷贝
数据流动:
- 外设--DMA-->内核--->用户空间
- 用户空间--->内核---->外设
第二步的时候,数据写到内核时方法就返回了,之后由操作系统调度,将数据写到外设
二代目拷贝——三次拷贝
数据流动:
- 外设--DMA-->内核空间缓存
- 内核缓存-->socket缓存
- socket缓存-->外设
数据不再需要拷贝至用户控件,但依旧有从内核缓存拷贝至socket缓存的过程。
三代目拷贝——零拷贝
原视频P51 30分钟处
流程如下:
- 数据从外设通过DMA读取至内核缓存
- 内核缓存将文件描述符(包含了数据在内核缓存的位置,以及长度)发送给socket缓存
- protocol engine使用gather的方式
- 从socket缓存读取数据的位置与长度
- 从内核缓存读取数据
三代目拷贝与二代目拷贝的区别是:
- 二代目拷贝会把整个数据从内核缓存传到socket缓存
- 三代目拷贝只把数据的描述信息传到socket缓存(这个数据量是极小的)。之后数据直接从内核缓存传到外设。
所以没有多余的数据拷贝动作,是效率最高的。这正是netty的零拷贝机制。
老师心语
如果能弄明白零拷贝的机制,不管是面试还是与同事的讨论中,都能极大地增加你的逼格。