减少拷贝次数的一种方法是调用mmap()来代替read调用,调用mmap(),内核会把数据通过DMA拷贝到内核缓冲区,然后不发往用户空间,而是直接将数据拷贝到socket缓冲区或者其他硬盘缓冲区。原本数据从硬盘发送到网卡需要经过四次上下文切换和四次数据拷贝——从硬盘到内核缓冲区,从内核缓冲区到用户空间,从用户空间到内核缓冲区,从内核缓冲区到socket缓冲区。使用mmap后需要经过相同过的四次上下文切换和三次数据拷贝,但是mmap调用返回时数据不再从内核拷贝到用户空间,少了一次内存拷贝。零拷贝技术是使用虚拟内存技术实现的物理内存共享机制。

Linux 零拷贝技术教程

系统调用sendfile()在代表输入文件的描述符in_fd和代表输出文件的描述符out_fd之间传送文件内容(字节)。描述符out_fd必须指向一个套接字,而in_fd指向的文件必须是可以mmap的。这些局限限制了sendfile的使用,使sendfile只能将数据从文件传递到套接字上,反之则不行。
使用sendfile不仅减少了数据拷贝的次数,还减少了上下文切换,数据传送始终只发生在kernel space


标签: Linux, 技术, 内核, 拷贝, 缓冲区, mmap, sendfile, fd

相关文章推荐

添加新评论,含*的栏目为必填