10.6.2 sendfile

1.传统Linux中 I/O 的问题
2.传统的 Linux 系统的标准 I/O 接口( read、 write)是基于数据拷贝的,也就是数据都是 copy_to_user 或者 copy_from_user,这样做的好处是,通过中间缓存的机制,减少磁盘 I/O 的操作,但是坏处也很明显,大量数据的拷贝,用户态和内核态的频繁切换,会消耗大量的 CPU 资源,严重影响数据传输的性能,统计表明,在Linux协议栈中, 数据包在内核态和用户态之间的拷贝所用的时间甚至占到了数据包整个处理流程时间的57.1%
3.什么是零拷贝
4.零拷贝就是上述问题的一个解决方案,通过尽量避免拷贝操作来缓解 CPU 的压力。零拷贝并没有真正做到“0” 拷贝,它更多是一种思想,很多的零拷贝技术都是基于这个思想去做的优化

 

 

 

 

 

 

posted @ 2021-04-07 16:30  huakai201  阅读(77)  评论(0编辑  收藏  举报