零拷贝 最大2G文件 FileChannel.transferTo(long position, long count, WritableByteChannel target)

正常拷贝:  磁盘  -> 内核空间  - > user空间 -> 内核空间 -> 目的缓冲区

零拷贝方式  :  磁盘  -> 内核空间  - >目的缓冲区

  为FileChannel.transferTo(long position, long count, WritableByteChannel target)//将数据从文件通道传输到了给定的可写字节通道

  1. DMA从拷贝至内核缓冲区
  2. cpu将数据从内核缓冲区拷贝至内核空间(socket缓冲区)
  3. DMA将数据从内核拷贝至协议引擎
  4. 这三个过程中共发生2次上下文切换,分别为发起读取文件和发送数据

 

 

 

 

 原来的拷贝方式

零拷贝方式    磁盘  -> 内核空间  - >目的缓冲区

 

posted @ 2018-07-02 12:10  star521  阅读(2602)  评论(0编辑  收藏  举报