大家好,我是树哥。
创新互联建站专注于始兴企业网站建设,成都响应式网站建设公司,商城开发。始兴网站建设公司,为始兴等地区提供建站服务。全流程按需规划网站,专业设计,全程项目跟踪,创新互联建站专业和态度为您提供的服务
相信大家在学习 Kafka 的时候,都会被问到:为啥 Kafka 这么快?许多朋友都会回答是因为 zero-copy 技术。而一说到 Zero-copy 就会说到 DMA 技术。
但 DMA 技术到底是啥?它诞生的背景是什么?它解决了什么问题?估计很多人就不知道了。今天就让我带大家盘一盘 DMA 技术!
DMA,全称 Direct Memory Access,即直接存储器访问。
DMA 传输将数据从一个地址空间复制到另一个地址空间,提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。
从 DMA 的定义我们可以知道,其主要是用来传输数据,并且是在外设和存储器或者存储器与存储器之间传输数据。
那为啥要通过 DMA 来进行传输数据呢?
原因是:之前传输数据需要 CPU 参与,在大量数据传输时会消耗 CPU 资源。
因此为了提升 CPU 利用率,出现了 DMA 技术,即直接让内存与磁盘进行数据传输。
在 DMA 技术出现之前,Linux 通过 I/O 中断的方式来传输数据,其流程如下图所示:
IO 中断方式的数据传输流程
用户进程由内核态切换回用户态,解除阻塞状态,然后等待 CPU 的下一个执行时间钟。
从上述流程可以看到,CPU 需要参与到「磁盘缓冲区拷贝到内核缓冲区」、「内核缓冲区拷贝到用户缓存区」这两个过程,极大地消耗了 CPU 资源。但有了 DMA 技术之后,其过程变成了这样:
DMA 方式的数据传输流程
仔细对比加入 DMA 技术之后的数据传输流程,我们可以发现 DMA 技术优化了数据从磁盘缓冲区拷贝到内核缓冲区这个过程,减少了这个过程里 CPU 的参与。
我们知道数据传输本质上还是需要 CPU 去处理的,那 DMA 技术怎么实现不需要 CPU 参与就能实现数据传输呢?
虽然我并没有仔细地看过 DMA 的实现原理,但可以大胆预测的是:其实 DMA 技术还是有用 CPU,只不过其没有用服务器的 CPU,而是自己配了一个计算单元,专门用于做数据传输。这就有点像 CPU 既可以做普通计算又可以做图形计算一样,但因为图形渲染太复杂,于是搞出来了个 GPU 专门做图形渲染一样。
DMA 本质是就是一个硬件技术,其实际样子是主板上的一个芯片,即 DMAC (DMA Controller DMA 控制器)以及 I/O 设备上的 DMAC 芯片。
通过在各个 I/O 设备上都加了 DMAC 芯片,以网卡为例,用户发送数据,当数据被映射到内核后,CPU 只需要告诉 DMAC 这个芯片,「我」要发 xxx 数据,打算发到哪里去,你帮我去做吧,然后 CPU 就可以走了,继续做其它事情。
DMA 最有价值的地方体现在当要传输的数据特别大、还要求速度特别快的时候,可以有效减少 CPU 的阻塞时间。
目前大多数的硬件设备,包括磁盘控制器、网卡、显卡以及声卡等都支持 DMA 技术。通过 DMA 和虚拟内存技术,我们实现了 Zero Copy 的目标,IO 设备跟用户程序空间传输数据的过程中,减少数据拷贝次数,减少系统调用,实现 CPU 的零参与,彻底消除 CPU 在这方面的负载。
所谓的 DMA(Direct Memory Access,即直接存储器访问)其实是一个硬件技术,其主要目的是减少大数据量传输时的 CPU 消耗,从而提高 CPU 利用效率。其本质上是一个主板和 IO 设备上的 DMAC 芯片。CPU 通过调度 DMAC 可以不参与磁盘缓冲区到内核缓冲区的数据传输消耗,从而提高效率。
当前标题:系统CPU效率高,DMA技术功不可没!
标题网址:http://www.mswzjz.cn/qtweb/news48/297348.html
温江区贝锐智能技术服务部_成都网站建设公司,为您提供营销型网站建设、软件开发、小程序开发、建站公司、商城网站、网站改版
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能