认识零拷贝[通俗易懂]

认识零拷贝[通俗易懂]注意事项(1)零拷贝的含义是数据不从内核空间拷贝到用户空间,也不从用户空间拷贝到内核空间(2)零拷贝完全依赖操作系统,操作系统提供了就是提供了,没有提供就没有提供,java本身做不了任何事情传统的IO拷贝需求java读取磁盘上的文件,并且输出出去。这个过程包含两个步骤,一个是读,一个是写图片解读三列分别为用户空间、内核空间、硬件(1)read()syscall…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

注意事项

(1)零拷贝的含义是数据不从内核空间拷贝到用户空间,也不从用户空间拷贝到内核空间

(2)零拷贝完全依赖操作系统,操作系统提供了就是提供了,没有提供就没有提供,java本身做不了任何事情

传统的IO拷贝

需求

java读取磁盘上的文件,并且输出出去。这个过程包含两个步骤,一个是读,一个是写

图片解读

认识零拷贝[通俗易懂]

三列分别为用户空间、内核空间、硬件

  • (1)read() syscall :java客户端(jvm虚拟机)向操作系统发起读磁盘数据的请求
  • (2)ask for data :系统向磁盘读数据
  • (3)data to kernel buffer through DMA: 磁盘数据通过DMA读到内核缓存区
  • (4)copy data to user buffer :把数据内核缓冲区复制到用户缓冲区(java堆)中
  • (5)code logic coutinues:业务逻辑处理
  • (6)wirte() syscall,copies data to kernel socket buffer:java客户端向系统发起写请求,并且把用户缓冲区(java堆)数据复制到内核缓冲区
  • (7)weites data:从内核缓冲区写到磁盘
  • (8)done:返回结果
  • (9)write() returns:返回写入结果

图片分析

上图有4次上下文切换:

(1)read() syscall :java客户端(jvm虚拟机)向操作系统发起读磁盘数据的请求  —-》从用户态切换为内核态

(4)copy data to user buffer :把数据内核缓冲区复制到用户缓冲区(java堆)中—-》从内核态切换为用户态

(6)wirte() syscall,copies data to kernel socket buffer:java客户端向系统发起写请求,并且把用户缓冲区(java堆)数据复制到内核缓冲区—-》从用户态切换为内核态

(9)write() returns:返回写入结果—-》从内核态切换为用户态

上图有2次没有必要的数据拷贝(假设没有步骤5):

(4)copy data to user buffer :把数据内核缓冲区复制到用户缓冲区(java堆)中

(6)wirte() syscall,copies data to kernel socket buffer:java客户端向系统发起写请求,并且把用户缓冲区(java堆)数据复制到内核缓冲区

代码

InputStream 、OutputStream

Socket基础使用_CBeann的博客-CSDN博客

零拷贝

图片解读 

  • (1)sendfile() syscall : java客户端(jvm虚拟机)向操作系统发起读磁盘数据sendfile的请求
  • (2)ask for data :系统向磁盘读数据
  • (3)data to kernel buffer through DMA: 磁盘数据通过DMA读到内核缓存区
  • (4)wirte data to target socket buffer:从内核空间缓冲区写到socket缓冲区
  • (5)writes data:socket向目标发送数据
  • (6)done:返回结果
  • (7) sendfile() returns :返回sendfile结果

认识零拷贝[通俗易懂]

图片分析

上图有2次上下文切换(比传统的IO减少了2次切换):

(1)sendfile() syscall : java客户端(jvm虚拟机)向操作系统发起读磁盘数据sendfile的请求 —-》从用户态切换为内核态

(7) sendfile() returns :返回sendfile结果—-》从内核态切换为用户态

上图有3次数据拷贝(比传统的IO减少了1次):

(3)data to kernel buffer through DMA: 磁盘数据通过DMA读到内核缓存区

(4)wirte data to target socket buffer:从内核空间缓冲区写到socket缓冲区

(5)writes data:socket向目标发送数据

代码

 fileChannel.transferTo(, , );
 fileChannel.transferFrom(, , );

零拷贝升级版

升级版需要解决的问题:

上面零拷贝的第四步((4)从内核空间缓冲区写到socket缓冲区)是可以优化的

图片解读

看图片的下半部分:

看kernel buffer —————> socket buffer

Linux2.4之前的零拷贝是把 kernel buffer 中全部的数据 拷贝 到 socket buffer

Linux2.4之后的零拷贝是把kernel buffer中的地址和数据长度拷贝到到 socket buffer(优化后),类似

当真正发送数据的时候,客户端会从socketbuffer中拿到地址和数据长度找到kernel buffer 进行发送

这个过程只有2次数据拷贝,是真正意义上的零拷贝

认识零拷贝[通俗易懂]

认识零拷贝[通俗易懂]

参考

2018年最新深入netty 零基础到精通 张龙老师

视频去哪了呢?_哔哩哔哩_bilibili

Netty、Kafka中的零拷贝技术到底有多牛?

https://mp.weixin.qq.com/s/dt0h2UhaoRECvjpeMZMsUA   (☆)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/191078.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JS如何把Object对象的数据输出到控制台中

    JS如何把Object对象的数据输出到控制台中       前端时间在编写程序时遇到这样一个问题,即在前端页面通过一些js框架自带的异步请求返回的数据类型为Object数据类型,笔者根据网上查阅到的资料,找到以下这种简单的方式://把Object类型转为Json数据格式,再通过console命令在控制台中打印出来console.log(“xhr的值为:”+JSON.st…

    2022年8月30日
    2
  • Celer cBridge 主网上线:无缝桥接跨链和跨层流动性

    Celer cBridge 主网上线:无缝桥接跨链和跨层流动性CelercBridgev1.0版本今天正式主网上线!用户可以立即使用cBridge在Ethereum、Arbitrum、BinanceSmartChain以及Polygon进行高速低成本跨链和跨层转账。cBridge将会在短期内支持更多的layer2和layer1区块链的跨链转账。此外,任何人都将能够通过运行cBridge节点加入cBridge网络以提供跨链跨层流动性,同时通过收取手续费产生收益。cBridge是一个重要的里程碑,它标志着Celer将在未来的多链多层区块链扩容生态下,提..

    2022年6月4日
    26
  • goland 2022.01 激活码【2021.10最新】

    (goland 2022.01 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月31日
    234
  • pythoncharm注释快捷键_多行注释以什么开头

    pythoncharm注释快捷键_多行注释以什么开头PyCharm多行注释快捷键为Ctrl+/。

    2022年8月29日
    3
  • c++中数组下标越界输出什么_C语言数组的越界和溢出

    c++中数组下标越界输出什么_C语言数组的越界和溢出引言最近突然想到当数组array有2个元素,而访问其array[2]时会不会编译错误的问题,答案是编译的时候不报错,只有运行的时候才报错。感悟以下是我测试用的代码,程序可以正常编译,且编译正确,只是在运行的时候出现程序崩溃。chararray[2]={‘2′,’3’};std::cout<<array[2]<<std::endl;//编译正常,运行的时候出现问题基于上述现象,说明程序在编译的时候没有进行下标越界的检查,当一个程序生成可执行文件的时候

    2022年10月2日
    5
  • 功率放大器电路设计「建议收藏」

    功率放大器电路设计「建议收藏」一、实验目的掌握功率放大器的设计方法。了解功率放大器的测试方法。二、实验内容及结果实验内容自主设计一低频功率放大器,满足如下要求:(1)输入正弦信号电压有效值为5mV,在8Ω电阻负载(一端接地)上,输出功率大于1W,输出波形无明显失真;(2)通频带为20Hz~20kHz;(3)输入电阻为600Ω。实验具体要求如下:(1)设计电路,利用Multisim软件绘制电路原理图。(2)阐述功率放大原理。(3)在输入信号有效值为5mV下,测量负载电压有效值,计算实际输出功率,验证是否满

    2022年6月6日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号