一、与epoll媲美的io_uring
1. io_uring原理
io_uring是linux5.1版本中引入的一种异步IO机制,它是一套全新的系统调用,它的设计目的是为了克服传统 Posix api 接口存在的限制,提供更高的性能和更好的可扩展性。

- io_uring通过使用共享内存和环形缓冲区机制,io_uring 减少了应用程序与内核之间交互所需的系统调用次数,从而降低了开销,它会申请一块用户态与内核态共享的内存,并再这块内存中建立一个环形队列,以此来实现用户与内核的通信,避免不必要的拷贝以此提高性能。
- 它的实现过程为每个io_uring实例映射一个fd,然后调用io_uring_setup系统调用分配一块共享内存,通过mmap映射到用户态。

同步与异步:
同步:通常是顺序执行,需要等待函数返回结果
异步:无需马上进入等待,可以自行选择发送报文或等待
环形缓冲区:
也叫循环队列,比如一个队列有5个位置,之前存入5个数据会依次占满队列,那么当第六个数据存入时,会计算6除以5余1,于是第六个数据存入第一个位置并覆盖原有数据。
2. io_uring主要API
io_uring的3个系统调用api
初始化 io_uring环, 创建了一个io_uring实例并返回一个fd,用于后续io_uring操作
1. int io_uring_setup(unsigned entries, struct io_uring_params *p);
+ 参数entries指定了io_uring 环的大小,
+ 而io_uring_params 结构体包含了其他的一些初始化参数,如 io_uring 的特性和行为等
用于提交 I/O 操作到 io_uring 环,一旦 I/O 操作被提交它会被内核异步处理
2. int io_uring_enter(int fd, unsigned to_submit, unsigned min_complete, unsigned flags, sigset_t *sig);
+ 参数fd是之前通过io_uring_setup()返回的文件描述符fd
+ to_submit 指定要提交的I/O操作数量
+ min_complete 指定最小要完成的I/O操作数量,
+ flags 是控制 I/O 操作行为的一些标志
+ sig 是一个可选的信号集合,在完成I/O操作时通知应用程序
用于注册文件描述符到 io_uring 环中,以便进行I/O操作
3. int io_uring_register(int fd, unsigned opcode, const void *arg, unsigned nr_args);
+ 参数 fd 是文件描述符,
+ opcode 是操作码,指定了要执行的操作类型,
+ arg 是指向操作参数的指针,
+ nr_args 是参数的数量
io_uring常用编程api
//1. io_uring_queue_init();
用于初始化 io_uring 队列。它会分配并初始化一个 io_uring 对象,并返回一个指向该对象的指针
struct io_uring *io_uring_queue_init(unsigned entries, struct io_uring_params *p);
//2. io_uring_prep_read(); / io_uring_prep_write();
用于准备读取和写入操作的函数。这些函数将指定的文件描述符和缓冲区等参数填充到 io_uring 操作数据结构中。其原型为:
void io_uring_prep_read(struct io_uring_sqe *sqe, int fd, void *buf

:io_uring异步io机制&spm=1001.2101.3001.5002&articleId=146189092&d=1&t=3&u=27e9ecf701034268b2392ba441511e5f)
1436

被折叠的 条评论
为什么被折叠?



