Libvirt之event loop
- Event driven programming
- The event loop API
- Worker pool
本文主要讲述 libvirt 所使用的 event loop 方法,以及 server 端和 client 端如何通过 event loop 交互。
event驱动的程序
一般,一个程序只 run 一次并终止,这种类型的程序很常见,尤其是在小型程序中,但是这样做的缺点也很明显:缺少用户交互。
这种方法,不适合所有应用,例如 GUI 应用会把大部分时间花在等待用户输入上,只有当用户点击鼠标,或者键盘输入,才会生成一个 event ,接下来 GUI 应用会响应该 event ,并执行对应的函数。 广义来说,这是大多数daemon进程运行的方式,如 libvirt 。即使 libvirt 不直接与用户输入交互且没有GUI接口。

event loop
在 Libvirt 中,该方法配合 poll(2) 使用,所有与客户端的交互、与其管理的 domain 的交互(domain , 指虚机实例)都通过 socket 完成。 所以,当客户端发起连接时,libvirt 会监控一个专门的文件描述符来捕获 event ,也即 messages 。
注:关于poll的用法,请参考man 2 poll
event loop API简介
event loop 提供以下 API:
src/util/virevent.c
- virEventAddHandle: 注册文件描述符所监控的

本文深入探讨了Libvirt中的event loop机制,包括event-driven编程、event loop API介绍、worker pool的工作流程,以及event loop的处理过程。libvirt利用poll(2)监控文件描述符以处理客户端交互和domain管理,通过worker threads优化并发处理,确保高效响应。
最低0.47元/天 解锁文章
792





