linux内核库aio
背景介绍
图 1. 基本 Linux I/O 模型的简单矩阵
两种头文件:
原生的AIO_ABI方法 /usr/include/linux/aio_abi.h /usr/include/aio.h
通过无名信号量signal机制来判断是否IO完成。
表 1. AIO 接口 API
API 函数 | 说明 |
---|---|
aio_read | 请求异步读操作 |
aio_error | 检查异步请求的状态 |
aio_return | 获得完成的异步请求的返回状态 |
aio_write | 请求异步写操作 |
aio_suspend | 挂起调用进程,直到一个或多个异步请求已经完成(或失败) |
aio_cancel | 取消异步 I/O 请求 |
lio_listio | 发起一系列 I/O 操作 |
集成的libaio方法 /usr/include/libaio.h
libaio不是centos原生的支持,需要手动安装开发库 离线或yum等安装
iocb数据结构:
iocb数据结构:它支持单个的io操作(io_iocb_common),也支持成批的IO处理(io_iocb_vector),还支持基于polling 模式(linux按键驱动)。
struct iocb在内核中又对应到struct kioctx结构。
便于调用,还封装好了多个常用的inline函数 (宏定义) ,宏定义都是操作struct iocb的结构体:
1、static inline void io_set_callback(struct iocb *i