<html>
<head>
<style><!--
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 12pt;
font-family:Calibri
}
--></style></head>
<body class='hmmessage'><div dir='ltr'>Hi all,<br>sorry for the late reply.<br><br>I noticed that I missed the deviceId property on my additional-nic line below, but I can confirm that the engine vm (installed with my previously modified template in /usr/share/ovirt-hosted-engine-setup/templates/vm.conf.in as outlined below) is still up and running (apparently) ok without it (I verified that the deviceId property has not been added automatically in /etc/ovirt-hosted-engine/vm.conf).<br><br>I admit that modifying a package file not marked as configuration (under /usr/share... may the FHS forgive me... :) is not best practice, but modifying the configuration one (under /etc...) afterwards seemed more error prone (needs propagation to further nodes).<br><br>In order to have a clear picture of the matter (and write/add-to a wiki page on engine vm customization) I'd like to read more on the syntax of these vm.conf files (they are neither libvirt XML files nor OTOPI files) and which properties are default/needed/etc.<br><br>From simple analogy, as an example, I thought that an unique index property would be needed (as in ide/virtio disk devices) for adding a nic, but Andrew example does not add it...<br><br>Any pointers to doc/code for further enlightenment?<br><br>Many thanks in advance,<br>Giuseppe<br><br><div>&gt; Date: Thu, 10 Apr 2014 08:40:25 +0200<br>&gt; From: sbonazzo@redhat.com<br>&gt; To: andrew@andrewklau.com<br>&gt; CC: giuseppe.ragusa@hotmail.com; josh@wrale.com; users@ovirt.org<br>&gt; Subject: Re: [Users] Post-Install Engine VM Changes Feasible?<br>&gt; <br>&gt; <br>&gt; <br>&gt; Hi,<br>&gt; <br>&gt; <br>&gt; Il 10/04/2014 02:40, Andrew Lau ha scritto:<br>&gt; &gt; On Tue, Apr 8, 2014 at 8:52 PM, Andrew Lau &lt;andrew@andrewklau.com&gt; wrote:<br>&gt; &gt;&gt; On Mon, Mar 17, 2014 at 8:01 PM, Sandro Bonazzola &lt;sbonazzo@redhat.com&gt; wrote:<br>&gt; &gt;&gt;&gt; Il 15/03/2014 12:44, Giuseppe Ragusa ha scritto:<br>&gt; &gt;&gt;&gt;&gt; Hi Joshua,<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; ------------------------------------------------------------------------------------------------------------------------------------------------------<br>&gt; &gt;&gt;&gt;&gt; Date: Sat, 15 Mar 2014 02:32:59 -0400<br>&gt; &gt;&gt;&gt;&gt; From: josh@wrale.com<br>&gt; &gt;&gt;&gt;&gt; To: users@ovirt.org<br>&gt; &gt;&gt;&gt;&gt; Subject: [Users] Post-Install Engine VM Changes Feasible?<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Hi,<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; I'm in the process of installing 3.4 RC(2?) on Fedora 19.  I'm using hosted engine, introspective GlusterFS+keepalived+NFS ala [1], across six nodes.<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; I have a layered networking topology ((V)LANs for public, internal, storage, compute and ipmi).  I am comfortable doing the bridging for each<br>&gt; &gt;&gt;&gt;&gt; interface myself via /etc/sysconfig/network-scripts/ifcfg-*.<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Here's my desired topology: http://www.asciiflow.com/#Draw6325992559863447154<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Here's my keepalived setup: https://gist.github.com/josh-at-knoesis/98618a16418101225726<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; I'm writing a lot of documentation of the many steps I'm taking.  I hope to eventually release a distributed introspective all-in-one (including<br>&gt; &gt;&gt;&gt;&gt; distributed storage) guide.<br>&gt; <br>&gt; I hope you'll publish it also on ovirt.org wiki :-)<br>&gt; <br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Looking at vm.conf.in &lt;http://vm.conf.in&gt;, it looks like I'd by default end up with one interface on my engine, probably on my internal VLAN, as<br>&gt; &gt;&gt;&gt;&gt; that's where I'd like the control traffic to flow.  I definitely could do NAT, but I'd be most happy to see the engine have a presence on all of the<br>&gt; &gt;&gt;&gt;&gt; LANs, if for no other reason than because I want to send backups directly over the storage VLAN.<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; I'll cut to it:  I believe I could successfully alter the vdsm template (vm.conf.in &lt;http://vm.conf.in&gt;) to give me the extra interfaces I require.<br>&gt; &gt;&gt;&gt;&gt; It hit me, however, that I could just take the defaults for the initial install.  Later, I think I'll be able to come back with virsh and make my<br>&gt; &gt;&gt;&gt;&gt; changes to the gracefully disabled VM.  Is this true?<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; [1] http://www.andrewklau.com/ovirt-hosted-engine-with-3-4-0-nightly/<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Thanks,<br>&gt; &gt;&gt;&gt;&gt; Joshua<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; I started from the same reference[1] and ended up "statically" modifying vm.conf.in before launching setup, like this:<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; cp -a /usr/share/ovirt-hosted-engine-setup/templates/vm.conf.in /usr/share/ovirt-hosted-engine-setup/templates/vm.conf.in.orig<br>&gt; &gt;&gt;&gt;&gt; cat &lt;&lt; EOM &gt; /usr/share/ovirt-hosted-engine-setup/templates/vm.conf.in<br>&gt; &gt;&gt;&gt;&gt; vmId=@VM_UUID@<br>&gt; &gt;&gt;&gt;&gt; memSize=@MEM_SIZE@<br>&gt; &gt;&gt;&gt;&gt; display=@CONSOLE_TYPE@<br>&gt; &gt;&gt;&gt;&gt; devices={index:2,iface:ide,address:{ controller:0, target:0,unit:0, bus:1,<br>&gt; &gt;&gt;&gt;&gt; type:drive},specParams:{},readonly:true,deviceId:@CDROM_UUID@,path:@CDROM@,device:cdrom,shared:false,type:disk@BOOT_CDROM@}<br>&gt; &gt;&gt;&gt;&gt; devices={index:0,iface:virtio,format:raw,poolID:@SP_UUID@,volumeID:@VOL_UUID@,imageID:@IMG_UUID@,specParams:{},readonly:false,domainID:@SD_UUID@,optional:false,deviceId:@IMG_UUID@,address:{bus:0x00,<br>&gt; &gt;&gt;&gt;&gt; slot:0x06, domain:0x0000, type:pci, function:0x0},device:disk,shared:exclusive,propagateErrors:off,type:disk@BOOT_DISK@}<br>&gt; &gt;&gt;&gt;&gt; devices={device:scsi,model:virtio-scsi,type:controller}<br>&gt; &gt;&gt;&gt;&gt; devices={index:4,nicModel:pv,macAddr:@MAC_ADDR@,linkActive:true,network:@BRIDGE@,filter:vdsm-no-mac-spoofing,specParams:{},deviceId:@NIC_UUID@,address:{bus:0x00,<br>&gt; &gt;&gt;&gt;&gt; slot:0x03, domain:0x0000, type:pci, function:0x0},device:bridge,type:interface@BOOT_PXE@}<br>&gt; &gt;&gt;&gt;&gt; devices={index:8,nicModel:pv,macAddr:02:16:3e:4f:c4:b0,linkActive:true,network:lan,filter:vdsm-no-mac-spoofing,specParams:{},address:{bus:0x00,<br>&gt; &gt;&gt;&gt;&gt; slot:0x09, domain:0x0000, type:pci, function:0x0},device:bridge,type:interface@BOOT_PXE@}<br>&gt; &gt;&gt;&gt;&gt; devices={device:console,specParams:{},type:console,deviceId:@CONSOLE_UUID@,alias:console0}<br>&gt; &gt;&gt;&gt;&gt; vmName=@NAME@<br>&gt; &gt;&gt;&gt;&gt; spiceSecureChannels=smain,sdisplay,sinputs,scursor,splayback,srecord,ssmartcard,susbredir<br>&gt; &gt;&gt;&gt;&gt; smp=@VCPUS@<br>&gt; &gt;&gt;&gt;&gt; cpuType=@CPU_TYPE@<br>&gt; &gt;&gt;&gt;&gt; emulatedMachine=@EMULATED_MACHINE@<br>&gt; &gt;&gt;&gt;&gt; EOM<br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;&gt; Note that you should also be able to edit /etc/ovirt-hosted-engine/vm.conf after setup:<br>&gt; &gt;&gt;&gt; - put the system in global maintenance<br>&gt; &gt;&gt;&gt; - edit the vm.conf file on all the hosts running the hosted engine<br>&gt; &gt;&gt;&gt; - shutdown the vm: hosted-engine --vm-shutdown<br>&gt; &gt;&gt;&gt; - start again the vm: hosted-engine --vm-start<br>&gt; &gt;&gt;&gt; - exit global maintenance<br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;&gt; Giuseppe, Joshua: can you share your changes in a guide for Hosted engine users on ovirt.org wiki?<br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;<br>&gt; &gt;&gt; So would you simply just add a new line under the original devices line? ie.<br>&gt; &gt;&gt; devices={nicModel:pv,macAddr:00:16:3e:6d:34:78,linkActive:true,network:ovirtmgmt,filter:vdsm-no-mac-spoofing,specParams:{},deviceId:0c8a1710-casd-407a-94e8-5b09e55fa141,address:{bus:0x00,<br>&gt; &gt;&gt; slot:0x03, domain:0x0000, type:pci,<br>&gt; &gt;&gt; function:0x0},device:bridge,type:interface}<br>&gt; &gt;&gt;<br>&gt; &gt;&gt; Are there any good practices for getting the mac addr so it won't be<br>&gt; &gt;&gt; possible to clash with ones vdsm would generate? I assume the same<br>&gt; &gt;&gt; applies for deviceid?<br>&gt; &gt;&gt; Did you also change the slot?<br>&gt; &gt;&gt;<br>&gt; &gt; <br>&gt; &gt; This worked successfully:<br>&gt; &gt; <br>&gt; &gt; yum -y install python-virtinst<br>&gt; &gt; <br>&gt; &gt; # generate uuid and mac address<br>&gt; &gt; echo  'import virtinst.util ; print<br>&gt; &gt; virtinst.util.uuidToString(virtinst.util.randomUUID())' | python<br>&gt; &gt; echo  'import virtinst.util ; print virtinst.util.randomMAC()' | python<br>&gt; &gt; <br>&gt; &gt; hosted-engine --set-maintenance --mode=global<br>&gt; &gt; nano /etc/ovirt-hosted-engine/vm.conf<br>&gt; &gt; # insert under earlier nicModel<br>&gt; &gt; # replace macaddress and uuid from above<br>&gt; &gt; # increment slot (so it's not the same as above nicModel)<br>&gt; &gt; # modify ovirtmgmt to desired bridge interface<br>&gt; &gt; <br>&gt; &gt; devices={nicModel:pv,macAddr:00:16:3e:35:87:7d,linkActive:true,network:storage_network,filter:vdsm-no-mac-spoofing,specParams:{},deviceId:4c32c036-0e5a-e0b3-9ba7-bg3dfzbs40ae,address:{bus:0x00,slot:0x04,<br>&gt; &gt; domain:0x0000, type:pci,function:0x0},device:bridge,type:interface}<br>&gt; &gt; <br>&gt; &gt; hosted-engine --vm-shutdown<br>&gt; &gt; hosted-engine --vm-start<br>&gt; &gt; <br>&gt; &gt; hosted-engine --set-maintenance --mode=none<br>&gt; &gt; <br>&gt; &gt; However, this won't get propagated to any additional hosts that are<br>&gt; &gt; installed. I'm guessing it may be this file<br>&gt; &gt; /usr/share/ovirt-hosted-engine-setup/templates/vm.conf.in that gets<br>&gt; &gt; copied for new installs, but I don't have any new hosts to test with<br>&gt; &gt; right now.<br>&gt; <br>&gt; A few comments on above discussion:<br>&gt; <br>&gt; MAC address for Hosted Engine VM is already generated randomly by hosted-engine --deploy command and proposed as default in the question:<br>&gt; <br>&gt; 'You may specify a MAC address for the VM or accept a randomly generated default [@DEFAULT@]: '<br>&gt; <br>&gt; So it shouldn't be necessary to generate another one.<br>&gt; However, you can set the MAC address at interactive setup or by creating an answer.conf file with the following content:<br>&gt; <br>&gt; [environment:default]<br>&gt; OVEHOSTED_VM/vmMACAddr=str:00:16:3e:72:85:3f<br>&gt; <br>&gt; changing above mac address with whatever you want and running<br>&gt; hosted-engine --deploy --config-append=answer.conf<br>&gt; <br>&gt; Note that if you change /etc/ovirt-hosted-engine/vm.conf after deployment you must also update /etc/ovirt-hosted-engine/answers.conf<br>&gt; in order to have additional host to get the same configuration when you run hosted-engine --deploy.<br>&gt; Additional host already deployed need to be updated manually.<br>&gt; <br>&gt; Remember also that if there's interest in adding configuration steps while deploying you can open an RFE on bugzilla.<br>&gt; <br>&gt; I created an etherpad to allow you to list post install changes to vm.conf, so I can get a clue on what we're missing there.<br>&gt; http://etherpad.ovirt.org/p/hosted-engine-post-install-changes<br>&gt; <br>&gt; <br>&gt; &gt; <br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; I simply added a second nic (with a fixed MAC address from the locally-administered pool, since I didn't know how to auto-generate one) and added an<br>&gt; &gt;&gt;&gt;&gt; index for nics too (mimicking the the storage devices setup already present).<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; My network setup is much simpler than yours: ovirtmgmt bridge is on an isolated oVirt-management-only network without gateway, my actual LAN with<br>&gt; &gt;&gt;&gt;&gt; gateway and Internet access (for package updates/installation) is connected to lan bridge and the SAN/migration LAN is a further (not bridged) 10<br>&gt; &gt;&gt;&gt;&gt; Gib/s isolated network for which I do not expect to need Engine/VMs reachability (so no third interface for Engine) since all actions should be<br>&gt; &gt;&gt;&gt;&gt; performed from Engine but only through vdsm hosts (I use a "split-DNS" setup by means of carefully crafted hosts files on Engine and vdsm hosts)<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; I can confirm that the engine vm gets created as expected and that network connectivity works.<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Unfortunately I cannot validate the whole design yet, since I'm still debugging HA-agent problems that prevent a reliable Engine/SD startup.<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Hope it helps.<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; Greetings,<br>&gt; &gt;&gt;&gt;&gt; Giuseppe<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;&gt; _______________________________________________<br>&gt; &gt;&gt;&gt;&gt; Users mailing list<br>&gt; &gt;&gt;&gt;&gt; Users@ovirt.org<br>&gt; &gt;&gt;&gt;&gt; http://lists.ovirt.org/mailman/listinfo/users<br>&gt; &gt;&gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;&gt;<br>&gt; &gt;&gt;&gt; --<br>&gt; &gt;&gt;&gt; Sandro Bonazzola<br>&gt; &gt;&gt;&gt; Better technology. Faster innovation. Powered by community collaboration.<br>&gt; &gt;&gt;&gt; See how it works at redhat.com<br>&gt; &gt;&gt;&gt; _______________________________________________<br>&gt; &gt;&gt;&gt; Users mailing list<br>&gt; &gt;&gt;&gt; Users@ovirt.org<br>&gt; &gt;&gt;&gt; http://lists.ovirt.org/mailman/listinfo/users<br>&gt; <br>&gt; <br>&gt; -- <br>&gt; Sandro Bonazzola<br>&gt; Better technology. Faster innovation. Powered by community collaboration.<br>&gt; See how it works at redhat.com<br></div>                                               </div></body>
</html>