linux aio 线程,QEMU的几个线程

HOST将qemu当做一个普通的进程和其他进程统一调度,可以使用资源对qemu进行资源预留隔离(cpuset)和优先级提升(chrt)。qemu进程包含多个线程,分配给GUEST的每个vcpu都对应一个vcpu线程,另外qemu还有一个线程循环执行select专门处理I/O事件。

QEMU的主要线程:

主线程(main_loop),一个

vCPU线程,一个或者多个

I/O线程(aio),一个或者多个

worker thread(VNC/SPICE),一个

qemu里有个主线程处于无限循环,会做如下操作

IO线程里有个select函数,它阻塞在一个文件描述符(fd)集合上,等待其就绪。fd可以通过qemu_set_fd_handler()

运行到期的定时器,定时器通过qemu_mod_timer添加

运行BH(bottom-halves),BH通过qemu_bh_schedule添加

当文件描述符就绪,定期器到期或者BH被调度,相应的callback会被调用

qemu中还有一些worker threads。一些占用CPU较多的工作会明显增大主IO线程的IO处理延迟,这些工作可以放在专用的线程里,例如posix-aio-compat.c中实现了异步文件I/O,当有aio请求产生,该请求被置于队列,工作线程可以在qemu主线程之外处理这些请求。VNC就是这样一个例子,它用了一个专门的worker thread(ui/vnc-jobs.c)进行计算密集型的图像压缩和编码工作。

QEMU 的详细介绍:请点这里

QEMU 的下载地址:请点这里

相关阅读:

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux AIO(Asynchronous I/O)是一种异步I/O机制,它可以让应用程序在进行I/O操作时,不必等待I/O操作完成才返回,而是在I/O操作进行的同时可以继续执行其他任务。这种机制可以极大地提高I/O操作的效率和应用程序的并发性能。 下面是一个简单的Linux AIO使用示例: ```c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <fcntl.h> #include <aio.h> #include <errno.h> #define BUFSIZE 1024 int main(int argc, char *argv[]) { int fd, ret; char buf[BUFSIZE]; struct aiocb aiocb; // 打开文件 fd = open(argv, O_RDONLY); if (fd < 0) { perror("open"); exit(1); } // 初始化aiocb结构体 bzero(&aiocb, sizeof(struct aiocb)); aiocb.aio_fildes = fd; aiocb.aio_buf = buf; aiocb.aio_nbytes = BUFSIZE; aiocb.aio_offset = 0; // 异步读取文件 ret = aio_read(&aiocb); if (ret < 0) { perror("aio_read"); exit(1); } // 等待异步读取完成 while (aio_error(&aiocb) == EINPROGRESS) { printf("reading...\n"); sleep(1); } // 检查异步读取结果 ret = aio_return(&aiocb); if (ret < 0) { perror("aio_return"); exit(1); } // 输出读取结果 printf("read %d bytes: %s\n", ret, buf); // 关闭文件 close(fd); return 0; } ``` 以上代码会打开指定的文件,异步读取文件内容,等待异步读取完成,输出读取结果,并关闭文件。在这个示例中,aio_read()函数会立即返回,不会阻塞程序运行。如果要进行多个异步I/O操作,可以使用aio_suspend()函数等待所有异步I/O操作完成。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值