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 。
注: