首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

sendfile:Linux中的”零拷贝”

该调用在Linux中的原型为如下形式: extern ssize_t sendfile (int __out_fd, int __in_fd, off_t *offset, size_t __count...移植性问题 sendfile系统调用的问题之一,总体上来看,是缺少标准化的实现,这与open系统调用类些。sendfileLinux、Solaris或HP-UX中的实现有很大的不同。...这些实现差异中的一点在于Linux提供的sendfile,是定义为用于两个文件描述符之间和文件到socket之间的传输接口。...另一方面,HP-UX和Solaris中,sendfile只能用于文件到socket的传输。 第二点差异,是Linux没有实现向量化传输。...Solaris和HP-UX 中的sendfile系统调用包含额外的参数,用于消除为待传输数据添加头部的开销。 展望 Linux中“零拷贝”的实现还远未结束,并很可能在不久的未来发生变化。

1K40
您找到你想要的搜索结果了吗?
是的
没有找到

Linux Sendfile 的原理与优点

sendfile 函数在两个文件描写叙述符之间直接传递数据(全然在内核中操作,传送),从而避免了内核缓冲区数据和用户缓冲区数据之间的拷贝,操作效率非常高,被称之为零拷贝。...sendfile 函数的定义例如以下: #include ssize_t sendfile(int out_fd,int in_fd,off_t*offset,size_t...文件数据实际上是经过了四次 copy 操作: 硬盘 —> 内核buf —> 用户 buf —> socket 相关缓冲区(内核) —> 协议引擎 新方式 sendfilesendfile 系统调用则提供了一种降低以上多次...sendfile 系统调用是在 2.1 版本号内核时引进的: sendfile(socket, file, len); 执行流程例如以下: sendfile 系统调用,文件数据被 copy 至内核缓冲区...再由 user 缓冲区到 socket 相关 缓冲区的文件 copy,而在内核版本号 2.4 之后,文件描写叙述符结果被改变,sendfile 实现了更简单的方式,系统调用方式仍然一样,细节与 2.1

66620

sendfile函数「建议收藏」

sendfile函数在两个文件描述符之间直接传递数据(完全在内核中操作),从而避免了内核缓冲区和用户缓冲区之间的数据拷贝,效率很高,这被称为零拷贝。...sendfile函数的定义如下: #include ssize_t sendfile(int out_fd, int in_fd, off_t* offset, size_t...offset参数指定从读入文件流的哪个位置开始读,如果为空,则从in_fd文件描述符所指的文件的文件偏移位置开始读,并且sendfile会更新in_fd所指文件的文件偏移。...sendfile成功时返回传输的字节数,失败则返回-1并设置errno。...该函数的man手册明确指出in_fd必须是一个支持类似mmap函数的文件描述符,即它必须指向真实的文件,不能是socket和管道;在Linux2.6.33之前,out_fd必须是一个socket,而从Linux2.6.33

44610

Nginx sendfile原理详解

配置语法 语法: sendfile on | off; 默认值: sendfile off; 上下文: http,server,location,if in location 说明 sendfile值为...on,指定使用sendfile系统调用来传输文件。...sendfile系统调用在两个文件描述符之间直接传递数据(完全在内核中操作),从而避免了数据在内核缓冲区和用户缓冲区之间的拷贝,操作效率很高,被称之为零拷贝。...sendfile系统调用则提供了一种减少拷贝次数,提升文件传输性能的方法。...这个过程数据经历的拷贝操作如下: 硬盘—>内核缓冲区—>内核socket缓冲区—>协议引擎 带有DMA收集拷贝功能的sendfile 对于带有DMA收集拷贝功能的sendfile系统调用,还可以再减少一次内核缓冲区之间的拷贝

54820

使用X-Sendfile下载文件

X-Sendfile 通过 HTTP header 来实现:在 X-Sendfile 头中指定一个文件的地址来通告前web server。 不过,在默认情况下它是被大多数 web 服务器禁用的。...而不同的 web 服务器的实现也不一样,包括规定了不同的 X-Sendfile 头格式。如果配置不合理将无法完成文件下载。...不同的 web 服务器实现了不同的 HTTP 头 ,sendfile 头和使用的 web 服务器如下: X-Sendfile Apache, Lighttpd v1.5, Cherokee X-LIGHTTPD-send-file...Lighttpd v1.4 X-Accel-Redirect Nginx, Cherokee 使用 X-SendFile 的缺点是你失去了对文件传输机制的控制。...例如如果你希望在完成文件下载后执行某些操作,比如只允许用户下载文件一次,这个 X-Sendfile 是没法做到的,因为后台的 php 脚本并不知道下载是否成功。

58130

【Netty】mmap 和 sendFile 零拷贝原理

文章目录 一、 零拷贝 简介 二、 传统 BIO 数据拷贝分析 ( 4拷贝 4切换 ) 三、 mmap 内存映射 ( 3拷贝 4切换 ) 四、 sendFile 函数 ( Linux 2.1 优化 )...( 3拷贝2切换 ) 五、 sendFile 函数 ( Linux 2.4 优化 ) ( 2拷贝 2切换 ) 一、 零拷贝 简介 ---- 零拷贝作用 : 在网络编程中 , 如果要进行性能优化 , 肯定要涉及到零拷贝..., 使用零拷贝能极大的提升数据传输性能 ; 零拷贝类型 : mmap ( 内存映射 ) 和 sendFile; 数据角度分析 : 在零拷贝机制中 , 整个数据在内存中只有一份数据 , 非零拷贝机制中...函数 ( Linux 2.1 优化 ) ( 3拷贝2切换 ) ---- sendFileLinux 提供的函数 , 其实现了由 内核缓冲区 直接将数据拷贝到 Socket 缓冲区 , 该操作直接在内核空间完成...函数 ( Linux 2.4 优化 ) ( 2拷贝 2切换 ) ---- sendFileLinux 提供的函数 , 其在 Linux 2.4 版本中 , 直接将数据从 内核缓冲区 拷贝到 协议栈

59810

【Netty】mmap 和 sendFile 零拷贝原理

文章目录 一、 零拷贝 简介 二、 传统 BIO 数据拷贝分析 ( 4拷贝 4切换 ) 三、 mmap 内存映射 ( 3拷贝 4切换 ) 四、 sendFile 函数 ( Linux 2.1 优化 )...( 3拷贝2切换 ) 五、 sendFile 函数 ( Linux 2.4 优化 ) ( 2拷贝 2切换 ) 一、 零拷贝 简介 零拷贝作用 : 在网络编程中 , 如果要进行性能优化 , 肯定要涉及到零拷贝..., 使用零拷贝能极大的提升数据传输性能 ; 零拷贝类型 : mmap ( 内存映射 ) 和 sendFile; 数据角度分析 : 在零拷贝机制中 , 整个数据在内存中只有一份数据 , 非零拷贝机制中...函数 ( Linux 2.1 优化 ) ( 3拷贝2切换 ) sendFileLinux 提供的函数 , 其实现了由 内核缓冲区 直接将数据拷贝到 Socket 缓冲区 , 该操作直接在内核空间完成...函数 ( Linux 2.4 优化 ) ( 2拷贝 2切换 ) sendFileLinux 提供的函数 , 其在 Linux 2.4 版本中 , 直接将数据从 内核缓冲区 拷贝到 协议栈 中 ;

62610
领券