SPDK的块设备抽象层,从一个简单的示例程序讲起

最早的SPDK仅仅是一个NVMe驱动,但现在的SPDK已经不是原来的SPDK了,其功能涵盖了整个存储栈。为了能够实现丰富的功能,SPDK实现了一个块设备抽象层,其功能与Linux内核的块设备层类似,这个块设备抽象层称为BDEV。

块设备抽象层BDEV在整个SPDK栈中的位置如图所示,它位于中间位置。向下实现对多种不同类型块设备驱动的管理,除了NVMe外还有malloc (ramdisk),Linux AIO,virtio-scsi,Ceph RBD和Pmem等。向上则为协议层提供访问设备的统一接口。同时,在其内部则实现了一个公共的功能,比如快照、克隆和加密等功能。

我们自上而下简要分析一下BDEV,BDEV向上层主要提供访问的API。SPDK BDEV的API与Linux文件系统的API非常类似,主要是打开关闭设备和进行数据读写等功能。我们这里先简要介绍一下各个API的原型,后面会详细介绍每个API的实现。

SPDK的块设备抽象层,从一个简单的示例程序讲起_第1张图片

首先我们看一下BDEV这些API的函数原型,主要API如下所示。以打开BDEV设备为例,这里主要参数是设备名称,打开后会返回BDEV的设备描述结构体指针,这个指针类似Linux中的文件句柄。

int spdk_bdev_open_ext(const char *bdev_name, bool write, spdk_bdev_event_cb_t event_cb,

      void *event_ctx, struct spdk_bdev_desc **_desc)

void spdk_bde

你可能感兴趣的:(存储技术从入门到精通,java,开发语言,存储,Linux,SAN,SCSI)