理解零拷贝

零拷贝(Zero-copy)是一种旨在减少数据在计算机里复制次数的方法,以提高数据传输的效率。

下面用从硬盘读取一个文件,通过网络发送出去的场景来介绍零拷贝。

1. 传统拷贝方式

1.1. 古老的纯CPU的IO

CPU拷贝4次、内核态和用户态切换4次。

1.2. 现在有DMA的普通IO

CPU拷贝2次、DMA拷贝2次,内核态和用户态切换4次。

2. 零拷贝

因为传统的方式都是4次拷贝(cpu4次,或cpu2次+dma2次)、内核用户态切换4次,比较耗时,零拷贝的思路就是减少这两个步骤里的次数。

下面为了画图简略,把发起读的时候硬盘写入到硬盘缓冲区这一步省略掉(就是上面图中0.1、0.2、0.3、0.4的4个步骤在图中省略掉)

2.1. mmap+write

mmap即内存映射,让应用程序里的用户缓冲区的一块内存与内核缓冲区中的一块内存映射起来,这样就只需要1次cpu拷贝、2次DMA拷贝、4次切换。

2.2. sendfile

sendfile是linux提供的一个系统调用函数,相当于替代前面的read+write两次系统调用函数的调用。所以这个方法就是1次cpu拷贝、2次DMA拷贝、2次切换。

2.3. sendfile+DMA收集

DMA收集需要硬件支持,数据直接从内核缓冲区拷贝到网卡,同时把传输的数据描述信息通过socket缓冲区返回给程序,这样0次cpu拷贝、2次DMA拷贝、2次切换。真正的零拷贝了。

2.4. splice

必须要通过管道的方式从内核缓冲区到Socket缓冲区传输,这样0次cpu拷贝、2次DMA拷贝、2次切换,也是零拷贝。

相关推荐
IT_陈寒16 分钟前
Redis性能提升30%的秘密:5个被低估的高级命令实战解析
前端·人工智能·后端
追逐时光者30 分钟前
推荐 4 款基于 .NET 开源、功能强大的文件管理工具,助力高效的整理文件与文件夹!
后端·.net
SundayBear39 分钟前
基于MCU的文件系统
linux·服务器·单片机
风象南39 分钟前
告别日志“大海捞针”,基于SpringBoot的错误指纹聚类实现
spring boot·后端
爱隐身的官人3 小时前
Linux配置Java/JDK(解决Kali启动ysoserial.jar JRMPListener报错)暨 Kali安装JAVA8和切换JDK版本的详细过程
java·linux·kali
Algebraaaaa4 小时前
Linux 基本命令超详细解释第三期 grep | wc | 管道符‘|’ | echo | tail | 重定向符
linux
做运维的阿瑞5 小时前
Python零基础入门:30分钟掌握核心语法与实战应用
开发语言·后端·python·算法·系统架构
小生不才yz6 小时前
(三)命令管理-命令历史-history命令的使用
linux
猿究院-陆昱泽6 小时前
Redis 五大核心数据结构知识点梳理
redis·后端·中间件
yuriy.wang6 小时前
Spring IOC源码篇五 核心方法obtainFreshBeanFactory.doLoadBeanDefinitions
java·后端·spring