summaryrefslogtreecommitdiff
path: root/Documentation/howto/libvirt.rst
blob: 0b303d54c9c5f180b94470e89c2262342648bbbd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
..
      Licensed under the Apache License, Version 2.0 (the "License"); you may
      not use this file except in compliance with the License. You may obtain
      a copy of the License at

          http://www.apache.org/licenses/LICENSE-2.0

      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
      WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
      License for the specific language governing permissions and limitations
      under the License.

      Convention for heading levels in Open vSwitch documentation:

      =======  Heading 0 (reserved for the title in a document)
      -------  Heading 1
      ~~~~~~~  Heading 2
      +++++++  Heading 3
      '''''''  Heading 4

      Avoid deeper levels because they do not render well.

=========================
Open vSwitch with Libvirt
=========================

This document describes how to use Open vSwitch with Libvirt 0.9.11 or later.
This document assumes that you followed :doc:`/intro/install/general` or
installed Open vSwitch from distribution packaging such as a .deb or .rpm.  The
Open vSwitch support is included by default in Libvirt 0.9.11. Consult
www.libvirt.org for instructions on how to build the latest Libvirt, if your
Linux distribution by default comes with an older Libvirt release.

Limitations
-----------

Currently there is no Open vSwitch support for networks that are managed by
libvirt (e.g. NAT). As of now, only bridged networks are supported (those where
the user has to manually create the bridge).

Setup
-----

First, create the Open vSwitch bridge by using the ovs-vsctl utility (this must
be done with administrative privileges)::

    $ ovs-vsctl add-br ovsbr

Once that is done, create a VM, if necessary, and edit its Domain XML file::

    $ virsh edit <vm>

Lookup in the Domain XML file the ``<interface>`` section. There should be one
such XML section for each interface the VM has::

    <interface type='network'>
     <mac address='52:54:00:71:b1:b6'/>
     <source network='default'/>
     <address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
    </interface>

And change it to something like this::

    <interface type='bridge'>
     <mac address='52:54:00:71:b1:b6'/>
     <source bridge='ovsbr'/>
     <virtualport type='openvswitch'/>
     <address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
    </interface>

The interface type must be set to ``bridge``. The ``<source>`` XML element
specifies to which bridge this interface will be attached to. The
``<virtualport>`` element indicates that the bridge in ``<source>`` element is
an Open vSwitch bridge.

Then (re)start the VM and verify if the guest's vnet interface is attached to
the ovsbr bridge::

    $ ovs-vsctl show

Troubleshooting
---------------

If the VM does not want to start, then try to run the libvirtd process either
from the terminal, so that all errors are printed in console, or inspect
Libvirt/Open vSwitch log files for possible root cause.

Bug Reporting
-------------

Report problems to bugs@openvswitch.org.