2013-05-03 15:25:37 +01:00
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
2017-07-26 18:01:25 +01:00
|
|
|
<!DOCTYPE html>
|
2013-05-03 15:25:37 +01:00
|
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
2008-04-23 17:08:31 +00:00
|
|
|
<body>
|
|
|
|
<h1 >libvirt architecture</h1>
|
2010-10-24 08:46:32 +11:00
|
|
|
|
|
|
|
<p>
|
|
|
|
Currently libvirt supports 2 kind of virtualization, and its
|
|
|
|
internal structure is based on a driver model which simplifies
|
|
|
|
adding new
|
|
|
|
engines:
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<ul id="toc"></ul>
|
|
|
|
|
2017-07-26 15:52:42 +01:00
|
|
|
<h2><a id="Xen">Xen support</a></h2>
|
2010-10-24 08:46:32 +11:00
|
|
|
|
2008-04-23 17:08:31 +00:00
|
|
|
<p>When running in a Xen environment, programs using libvirt have to execute
|
|
|
|
in "Domain 0", which is the primary Linux OS loaded on the machine. That OS
|
|
|
|
kernel provides most if not all of the actual drivers used by the set of
|
|
|
|
domains. It also runs the Xen Store, a database of information shared by the
|
2018-03-28 17:51:41 -06:00
|
|
|
hypervisor, the backend drivers, any running domains, and libxl (aka libxenlight).
|
|
|
|
libxl provides a set of APIs for creating and managing domains, which can be used
|
|
|
|
by applications such as the xl tool provided by Xen or libvirt. The hypervisor,
|
2008-04-23 17:08:31 +00:00
|
|
|
drivers, kernels and daemons communicate though a shared system bus
|
|
|
|
implemented in the hypervisor. The figure below tries to provide a view of
|
|
|
|
this environment:</p>
|
|
|
|
<img src="architecture.gif" alt="The Xen architecture" />
|
2018-03-28 17:51:41 -06:00
|
|
|
<p>The library will interact with libxl for all management operations
|
|
|
|
on a Xen system.</p>
|
|
|
|
<p>Note that the libvirt libxl driver only supports root access.</p>
|
2010-10-24 08:46:32 +11:00
|
|
|
|
2018-03-31 16:51:14 +02:00
|
|
|
<h2><a id="QEMU">QEMU and KVM support</a></h2>
|
2010-10-24 08:46:32 +11:00
|
|
|
|
2018-03-31 16:51:14 +02:00
|
|
|
<p>The model for QEMU and KVM is completely similar, basically KVM is based
|
|
|
|
on QEMU for the process controlling a new domain, only small details differs
|
2008-04-23 17:08:31 +00:00
|
|
|
between the two. In both case the libvirt API is provided by a controlling
|
|
|
|
process forked by libvirt in the background and which launch and control the
|
2018-03-31 16:51:14 +02:00
|
|
|
QEMU or KVM process. That program called libvirt_qemud talks though a specific
|
|
|
|
protocol to the library, and connects to the console of the QEMU process in
|
2008-04-23 17:08:31 +00:00
|
|
|
order to control and report on its status. Libvirt tries to expose all the
|
2018-03-31 16:51:14 +02:00
|
|
|
emulations models of QEMU, the selection is done when creating the new
|
2008-04-23 17:08:31 +00:00
|
|
|
domain, by specifying the architecture and machine type targeted.</p>
|
2018-03-31 16:51:14 +02:00
|
|
|
<p>The code controlling the QEMU process is available in the
|
2008-04-23 17:08:31 +00:00
|
|
|
<code>qemud/</code> directory.</p>
|
2010-10-24 08:46:32 +11:00
|
|
|
|
2017-07-26 15:52:42 +01:00
|
|
|
<h2><a id="drivers">Driver based architecture</a></h2>
|
2010-10-24 08:46:32 +11:00
|
|
|
|
2008-04-23 17:08:31 +00:00
|
|
|
<p>As the previous section explains, libvirt can communicate using different
|
|
|
|
channels with the current hypervisor, and should also be able to use
|
|
|
|
different kind of hypervisor. To simplify the internal design, code, ease
|
|
|
|
maintenance and simplify the support of other virtualization engine the
|
|
|
|
internals have been structured as one core component, the libvirt.c module
|
|
|
|
acting as a front-end for the library API and a set of hypervisor drivers
|
|
|
|
defining a common set of routines. That way the Xen Daemon access, the Xen
|
|
|
|
Store one, the Hypervisor hypercall are all isolated in separate C modules
|
|
|
|
implementing at least a subset of the common operations defined by the
|
|
|
|
drivers present in driver.h:</p>
|
|
|
|
<ul>
|
|
|
|
<li>xend_internal: implements the driver functions though the Xen
|
|
|
|
Daemon</li>
|
|
|
|
<li>xs_internal: implements the subset of the driver available though the
|
|
|
|
Xen Store</li>
|
|
|
|
<li>xen_internal: provide the implementation of the functions possible via
|
|
|
|
direct hypervisor access</li>
|
|
|
|
<li>proxy_internal: provide read-only Xen access via a proxy, the proxy code
|
2010-02-21 14:56:23 +01:00
|
|
|
is in the <code>proxy/</code> directory.</li>
|
2008-04-23 17:08:31 +00:00
|
|
|
<li>xm_internal: provide support for Xen defined but not running
|
|
|
|
domains.</li>
|
2018-03-31 16:51:14 +02:00
|
|
|
<li>qemu_internal: implement the driver functions for QEMU and
|
2008-04-23 17:08:31 +00:00
|
|
|
KVM virtualization engines. It also uses a qemud/ specific daemon
|
2018-03-31 16:51:14 +02:00
|
|
|
which interacts with the QEMU process to implement libvirt API.</li>
|
2008-04-23 17:08:31 +00:00
|
|
|
<li>test: this is a test driver useful for regression tests of the
|
|
|
|
front-end part of libvirt.</li>
|
|
|
|
</ul>
|
|
|
|
<p>Note that a given driver may only implement a subset of those functions,
|
|
|
|
(for example saving a Xen domain state to disk and restoring it is only
|
|
|
|
possible though the Xen Daemon), in that case the driver entry points for
|
|
|
|
unsupported functions are initialized to NULL.</p>
|
|
|
|
<p></p>
|
|
|
|
</body>
|
|
|
|
</html>
|