vmfex
NOTE: There is a new hook with better integration to vNic profile management UCS Integration
This hook enables the use of Cisco VM Fabric Extender (VM-FEX) in oVirt.
The hook receives a VM’s virtual NIC’s MAC adress as it is defined in the engine and a FEX Port Profile name, and reattaches that NIC to the FEX Port instead of the logical network it is assigned to in the Engine. This way the NIC MACs can be controlled in the Engine, but the NIC is actually running on FEX.
Since the only unique parameter passed from the engine to the VM is the MAC, a dictionary-like mapping of MAC to port profile will be used.
Sample:
vmfex={'00:11:22:33:44:55:66':'Profile1', '00:11:22:33:44:55:67':'Profile2',...} (one line)
Will add 2 virtual nics attached to profile1 and profile2 using the vnic MAC addresses specified, replacing the actual NICs assigned to the VM.
A VM NIC with a MAC that is not mentioned in this dictionary will not be altered, and will remain attached to the bridge/logical network defined for it in the engine.
Libvirt internals (what the hook will do): Replace the existing interface xml:
with the following interface xml:
Note how <mac></mac>
is preserved
The hook also defines a dynamic pool of VM-FEX dynamic NICs on every host. Libvirt internals: dynamic network with libvirt (define a NIC pool, so libvirt can assign VMs to NICs dynamically):
<network>
<name>direct-pool</name>
<forward mode="passthrough">
<interface dev="eth3"></interface>
<interface dev="eth4"></interface>
<interface dev="eth5"></interface>
<interface dev="eth6"></interface>
<interface dev="eth7"></interface>
<interface dev="eth8"></interface>
<interface dev="eth9"></interface>
<interface dev="eth10"></interface>
<interface dev="eth11"></interface>
</forward>
</network>
Using libvirt, the network is defined like this (the hook uses libvirt python API for the same purpose, and does this automatically):
virsh net-define /tmp/direct-pool.xml
virsh net-start direct-pool
virsh net-autostart direct-pool
(where /tmp/direct-pool.xml
contains the xml above)
Note that these interface definitions are completely static - you never need to modify them due to migration, or starting up/shutting down the guest.