[libvirt-users] connecting host and guest vm using a dummy nic

Laine Stump laine at redhat.com
Tue May 1 14:30:59 UTC 2018


On 04/30/2018 03:16 PM, daggs wrote:
> Greetings Laine,
> 
>> Sent: Monday, April 30, 2018 at 8:31 PM
>> From: "Laine Stump" <laine at redhat.com>
>> To: libvirt-users at redhat.com
>> Cc: daggs <daggs at gmx.com>
>> Subject: Re: [libvirt-users] connecting host and guest vm using a dummy nic
>>
>> On 04/27/2018 06:39 PM, daggs wrote:
>>> Greetings all,
>>>
>>> I have a host machine that runs a router within a vm.
>>> I want to allow a connection between the host and the guest so the host can connect to the lan provided by the router vm.
>>> I've created a dummy interface with these commands:
>>> $ ip link add ens99-dummy type dummy
>>> $ ip link set ens99-dummy address 52:54:00:1f:d0:ff
>>>
>>> this resulted with this output:
>>> $ ifconfig ens99-dummy
>>> ens99-dummy Link encap:Ethernet  HWaddr 52:54:00:1F:D0:FF 
>>>           inet6 addr: fe80::84b5:24ff:fe62:c16d/64 Scope:Link
>>>           UP BROADCAST RUNNING NOARP  MTU:1500  Metric:1
>>>           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
>>>           TX packets:899 errors:0 dropped:0 overruns:0 carrier:0
>>>           collisions:0 txqueuelen:1000
>>>           RX bytes:0 (0.0 B)  TX bytes:321727 (314.1 KiB)
>>>
>>>
>>> in my libvirt's xml file I have this entry:
>>>     <interface type='direct'>
>>>       <mac address='52:54:00:0c:cb:3e'/>
>>>       <source dev='ens99-dummy' mode='private'/>
>>>       <target dev='macvtap0'/>
>>>       <model type='e1000'/>
>>>       <alias name='net0'/>
>>>       <address type='pci' domain='0x0000' bus='0x02' slot='0x01' function='0x0'/>
>>>     </interface>
>>
>> MY first question would be "Why are you using macvtap?" This
>> unnecessarily complicates the plumbing, leading to more potential places
>> where it could fail.
> misconfiguration, question is, what should be the exact config for this.
> 
>>
>> The 2nd question is - Have you looked at the dhcp server running on the
>> guest to verify that it is indeed listening for DHCP requests on the
>> guest-side interface associated with the macvtap interface, and that it
>> is receiving those requests and sending a reply?
> will test it. as said before, I'm not sure what should be the proper config in libvirt.
> 
>>
>>>
>>> after the vm is up, I see the adapter in the vm and the host has one more entry:
>>> $ ifconfig macvtap0
>>> macvtap0  Link encap:Ethernet  HWaddr 52:54:00:0C:CB:3E 
>>>           inet6 addr: fe80::5054:ff:fe0c:cb3e/64 Scope:Link
>>>           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
>>>           RX packets:0 errors:0 dropped:0 overruns:0 frame:0
>>>           TX packets:889 errors:0 dropped:0 overruns:0 carrier:0
>>>           collisions:0 txqueuelen:500
>>>           RX bytes:0 (0.0 B)  TX bytes:320523 (313.0 KiB)
>>>
>>> but when I try to request ip via dhcp from both macvtap0 and ens99-dummy I don't get any.
>>> any idea why?
>>
>> Definitely you wouldn't be able to use the macvtap0 device, so if
>> anything you would want to be using ens99-dummy, but I'm not even
>> certain *that* would work, as I've never tried it.
> so use ens99-dummy directly? 

My suggestion is to scrap the idea of using macvtap and a dummy link
entirely, and just use a plain tap device. I can't think of any reason
why you would want to use macvtap rather than tap in this case

> 
>>
>> You've provided no visibility into the configuration of the guest OS in
>> your virtual machine, but in general if you want a simple connection
>> between the host and guest that has *no other connections*, you can do
>> this with a bare tap device:

like this:

>>
>>     <interface type='ethernet'>
>>       <model type='e1000'/>
>>     </interface>
>>
>> This will show up as a single device on the host and a single device in
>> the guest, not connected to a bridge or a macvtap device or anything,
>> and will not need any other "ip link blah blah" type setup on the host.
>> Simplifying your setup in this manner may make it easier to find the
>> source of your problem.
>>
> 
> ok, here is the entire xml file:

(I actually meant the network configuration within the guest OS, not the
libvirt config of the virtual machine it's running on)


> 
> <domain type='kvm'>
>   <name>router</name>
>   <uuid>ed8eabe2-ced3-4224-aa12-60fb31dd3fd4</uuid>
>   <memory unit='KiB'>1048576</memory>
>   <currentMemory unit='KiB'>1048576</currentMemory>
>   <vcpu placement='static'>2</vcpu>
>   <os>
>     <type arch='x86_64' machine='pc-q35-2.8'>hvm</type>
>     <boot dev='hd'/>
>   </os>
>   <features>
>     <acpi/>
>     <apic/>
>   </features>
>   <cpu mode='host-passthrough'/>
>   <clock offset='utc'>
>     <timer name='rtc' tickpolicy='catchup'/>
>     <timer name='pit' tickpolicy='delay'/>
>     <timer name='hpet' present='no'/>
>   </clock>
>   <on_poweroff>destroy</on_poweroff>
>   <on_reboot>restart</on_reboot>
>   <on_crash>restart</on_crash>
>   <pm>
>     <suspend-to-mem enabled='no'/>
>     <suspend-to-disk enabled='no'/>
>   </pm>
>   <devices>
>     <emulator>/usr/bin/kvm</emulator>
>     <disk type='file' device='disk'>
>       <driver name='qemu' type='raw'/>
>       <source file='/home/router/lede-x86-64-combined-ext4.img'/>
>       <target dev='vda' bus='virtio'/>
>       <address type='pci' domain='0x0000' bus='0x05' slot='0x00' function='0x0'/>
>     </disk>
>     <controller type='usb' index='0' model='ich9-ehci1'>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x1d' function='0x7'/>
>     </controller>
>     <controller type='usb' index='0' model='ich9-uhci1'>
>       <master startport='0'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x1d' function='0x0' multifunction='on'/>
>     </controller>
>     <controller type='usb' index='0' model='ich9-uhci2'>
>       <master startport='2'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x1d' function='0x1'/>
>     </controller>
>     <controller type='usb' index='0' model='ich9-uhci3'>
>       <master startport='4'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x1d' function='0x2'/>
>     </controller>
>     <controller type='sata' index='0'>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x1f' function='0x2'/>
>     </controller>
>     <controller type='pci' index='0' model='pcie-root'/>
>     <controller type='pci' index='1' model='dmi-to-pci-bridge'>
>       <model name='i82801b11-bridge'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x1e' function='0x0'/>
>     </controller>
>     <controller type='pci' index='2' model='pci-bridge'>
>       <model name='pci-bridge'/>
>       <target chassisNr='2'/>
>       <address type='pci' domain='0x0000' bus='0x01' slot='0x00' function='0x0'/>
>     </controller>
>     <controller type='pci' index='3' model='pcie-root-port'>
>       <model name='ioh3420'/>
>       <target chassis='3' port='0x8'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x0' multifunction='on'/>
>     </controller>
>     <controller type='pci' index='4' model='pcie-root-port'>
>       <model name='ioh3420'/>
>       <target chassis='4' port='0x9'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x1'/>
>     </controller>
>     <controller type='pci' index='5' model='pcie-root-port'>
>       <model name='ioh3420'/>
>       <target chassis='5' port='0xa'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x2'/>
>     </controller>
>     <controller type='pci' index='6' model='pcie-root-port'>
>       <model name='ioh3420'/>
>       <target chassis='6' port='0xb'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x3'/>
>     </controller>
>     <controller type='pci' index='7' model='pcie-root-port'>
>       <model name='ioh3420'/>
>       <target chassis='7' port='0xc'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x4'/>
>     </controller>
>     <controller type='pci' index='8' model='pcie-root-port'>
>       <model name='ioh3420'/>
>       <target chassis='8' port='0xd'/>
>       <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x5'/>
>     </controller>
>     <interface type='direct'>
>       <mac address='52:54:00:e7:90:bc'/>
>       <source dev='ens99-dummy' mode='vepa'/>
>       <model type='rtl8139'/>
>       <address type='pci' domain='0x0000' bus='0x02' slot='0x01' function='0x0'/>
>     </interface>
>     <serial type='pty'>
>       <target type='isa-serial' port='0'/>
>     </serial>
>     <console type='pty'>
>       <target type='serial' port='0'/>
>     </console>
>     <input type='mouse' bus='ps2'/>
>     <input type='keyboard' bus='ps2'/>
>     <hostdev mode='subsystem' type='usb' managed='yes'>
>       <source>
>         <vendor id='0x148f'/>
>         <product id='0x5572'/>
>       </source>
>       <address type='usb' bus='0' port='1'/>
>     </hostdev>
>     <hostdev mode='subsystem' type='pci' managed='yes'>
>       <source>
>         <address domain='0x0000' bus='0x01' slot='0x00' function='0x0'/>
>       </source>
>       <address type='pci' domain='0x0000' bus='0x03' slot='0x00' function='0x0'/>
>     </hostdev>
>     <hostdev mode='subsystem' type='pci' managed='yes'>
>       <source>
>         <address domain='0x0000' bus='0x03' slot='0x00' function='0x0'/>
>       </source>
>       <address type='pci' domain='0x0000' bus='0x06' slot='0x00' function='0x0'/>
>     </hostdev>
>     <hostdev mode='subsystem' type='pci' managed='yes'>
>       <source>
>         <address domain='0x0000' bus='0x04' slot='0x00' function='0x0'/>
>       </source>
>       <address type='pci' domain='0x0000' bus='0x07' slot='0x00' function='0x0'/>
>     </hostdev>
>     <memballoon model='virtio'>
>       <address type='pci' domain='0x0000' bus='0x04' slot='0x00' function='0x0'/>
>     </memballoon>
>   </devices>
> </domain>
> 
> what I don't get is how to connect the interface above to the dummy one I've created.
> 

That's easy. Don't - see my suggestion above about using a tap device
instead of the macvtap+dummy combination (actually, I had thought the
"<source dev='ens99-dummy' ..." should connect the two, but according to
your experiments that doesn't result in a working setup, so...)




More information about the libvirt-users mailing list