https://www.51cto.com/article/720677.html

所谓的 DMA(Direct Memory Access,即直接存储器访问)其实是一个硬件技术,其主要目的是减少大数据量传输时的 CPU 消耗,从而提高 CPU 利用效率。其本质上是一个主板和 IO 设备上的 DMAC 芯片。CPU 通过调度 DMAC 可以不参与磁盘缓冲区到内核缓冲区的数据传输消耗,从而提高效率。

​大家好,我是树哥。

相信大家在学习 Kafka 的时候,都会被问到:为啥 Kafka 这么快?许多朋友都会回答是因为 zero-copy 技术。而一说到 Zero-copy 就会说到 DMA 技术。

但 DMA 技术到底是啥?它诞生的背景是什么?它解决了什么问题?估计很多人就不知道了。今天就让我带大家盘一盘 DMA 技术!

什么是 DMA?

DMA,全称 Direct Memory Access,即直接存储器访问。

DMA 传输将数据从一个地址空间复制到另一个地址空间,提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。

从 DMA 的定义我们可以知道,其主要是用来传输数据,并且是在外设和存储器或者存储器与存储器之间传输数据。

那为啥要通过 DMA 来进行传输数据呢?

原因是:之前传输数据需要 CPU 参与,在大量数据传输时会消耗 CPU 资源。

因此为了提升 CPU 利用率,出现了 DMA 技术,即直接让内存与磁盘进行数据传输。

在 DMA 技术出现之前,Linux 通过 I/O 中断的方式来传输数据,其流程如下图所示:

https://s6.51cto.com/oss/202210/17/f74b63a71f0c970634d908a02a0d5a7634f364.png

IO 中断方式的数据传输流程