<div class="xam_msg_class">
<div style="font: normal 13px Arial; color:rgb(31, 28, 27);">many thanks Juan it works!<br><br>best regards<br>a<br><br><br>
<div><span style="font-family:Arial; font-size:11px; color:#5F5F5F;">Da</span><span style="font-family:Arial; font-size:12px; color:#5F5F5F; padding-left:5px;">: "Juan Hernandez" jhernand@redhat.com</span></div>
<div><span style="font-family:Arial; font-size:11px; color:#5F5F5F;">A</span><span style="font-family:Arial; font-size:12px; color:#5F5F5F; padding-left:5px;">: "Amedeo Salvati" amedeo@oscert.net, users@ovirt.org</span></div>
<div><span style="font-family:Arial; font-size:11px; color:#5F5F5F;">Cc</span><span style="font-family:Arial; font-size:12px; color:#5F5F5F; padding-left:5px;">: </span></div>
<div><span style="font-family:Arial; font-size:11px; color:#5F5F5F;">Data</span><span style="font-family:Arial; font-size:12px; color:#5F5F5F; padding-left:5px;">: Tue, 22 Jul 2014 15:32:45 +0200</span></div>
<div><span style="font-family:Arial; font-size:11px; color:#5F5F5F;">Oggetto</span><span style="font-family:Arial; font-size:12px; color:#5F5F5F; padding-left:5px;">: Re: [ovirt-users] cloud-init options under python-sdk</span></div>
<br>
<div>&gt; On 07/22/2014 02:55 PM, Amedeo Salvati wrote:</div><div>&gt; &gt; hi Juan|guys,</div><div>&gt; &gt; </div><div>&gt; &gt; thanks for hints! but unfortunatly it seems wont works, because I've</div><div>&gt; &gt; launched vm with this simple code:</div><div>&gt; &gt; </div><div>&gt; &gt; action =</div><div>&gt; &gt; params.Action(vm=params.VM(initialization=params.Initialization(cloud_init=params.CloudInit(host=params.Host(name="rheltest014")))))</div><div>&gt; &gt; vm.start( action )</div><div>&gt; &gt; </div><div>&gt; &gt; but after boot the VM, cloud-init service hasn't set hostname and on</div><div>&gt; &gt; cloud-init.log and cloud-init-output.log I cannot find any entry for</div><div>&gt; &gt; setting hostname, instead if I use web ui it work's fine...</div><div>&gt; &gt; </div><div>&gt; &gt; there are any ways to debug cloud-init jobs?</div><div>&gt; &gt; the params params.Host is right for CloudInit host or is intended for</div><div>&gt; &gt; host / hypervisor?</div><div>&gt; &gt; </div><div>&gt; &gt; Best regards</div><div>&gt; &gt; Amedeo Salvati</div><div>&gt; &gt; </div><div>&gt; </div><div>&gt; To change the hostname you have to use the "address" property of the</div><div>&gt; "Host" class:</div><div>&gt; </div><div>&gt;   host=params.Host(</div><div>&gt;       address="myhostname.example.com"</div><div>&gt;   )</div><div>&gt; </div><div>&gt; The "Host" class is used for many things, including CloudInit and</div><div>&gt; hypervisors. But in this context it is just a container for the host name.</div><div>&gt; </div><div>&gt; To debug cloud-init start the VM (with the GUI or with the RESTAPI),</div><div>&gt; then go to the hypervisor where it is actually running, and look for the</div><div>&gt; corresponding qemu-kvm process:</div><div>&gt; </div><div>&gt;   # ps -ef | grep qemu-kvm | grep myvm</div><div>&gt; </div><div>&gt; The qemu-kvm command line will have a parameter indicating the file that</div><div>&gt; contains the cloud-init data:</div><div>&gt; </div><div>&gt;   -drive file=/var/run/vdsm/payload/...img</div><div>&gt; </div><div>&gt; Copy that file somewhere, then mount it and inspect the content:</div><div>&gt; </div><div>&gt;   # cp /var/run/vdsm/payload/...img /tmp/my.img</div><div>&gt;   # mount -o loop,ro /tmp/my.img /mnt</div><div>&gt;   # find /mnt</div><div>&gt;   ...</div><div>&gt;   # umount /mnt</div><div>&gt; </div><div>&gt; </div><div>&gt; &gt; Da: "Juan Hernandez" jhernand@redhat.com</div><div>&gt; &gt; A: "Amedeo Salvati" amedeo@oscert.net, users@ovirt.org</div><div>&gt; &gt; Cc:</div><div>&gt; &gt; Data: Tue, 22 Jul 2014 12:21:01 +0200</div><div>&gt; &gt; Oggetto: Re: [ovirt-users] cloud-init options under python-sdk</div><div>&gt; &gt; </div><div>&gt; &gt;&gt; On 07/22/2014 11:48 AM, Amedeo Salvati wrote:</div><div>&gt; &gt;&gt; &gt; hello guys!</div><div>&gt; &gt;&gt; &gt;</div><div>&gt; &gt;&gt; &gt; I'm writing some python code to start VMs, and based on operating system</div><div>&gt; &gt;&gt; &gt; (at this moment centos6 nad centos7), I would like to use cloud-init</div><div>&gt; &gt;&gt; &gt; options (available on web ui at run-once) to start them and resetting</div><div>&gt; &gt;&gt; &gt; root password, change hostname and write some configuration files by</div><div>&gt; &gt;&gt; &gt; using yaml semantics, but at this moment I was unable to find a way to</div><div>&gt; &gt;&gt; &gt; do it...</div><div>&gt; &gt;&gt; &gt;</div><div>&gt; &gt;&gt; &gt; somebody know a way (or could send me some hints) using python-sdk to</div><div>&gt; &gt;&gt; &gt; start A VM and pass to it cloud-init options?</div><div>&gt; &gt;&gt; &gt;</div><div>&gt; &gt;&gt; &gt; e.g. the portion of code I would like to change is vm.start() under</div><div>&gt; &gt; rhel6|7:</div><div>&gt; &gt;&gt; &gt;</div><div>&gt; &gt;&gt; &gt; try:</div><div>&gt; &gt;&gt; &gt; osVersion = vm.get_os().get_type()</div><div>&gt; &gt;&gt; &gt; if (osVersion == "rhel_6x64" or osVersion == "rhel_6" or</div><div>&gt; &gt;&gt; &gt; osVersion == "rhel_7x64") and CLOUDINIT == "yes":</div><div>&gt; &gt;&gt; &gt; print "Starting VM: " + vm.name + " with cloud-init</div><div>&gt; &gt;&gt; &gt; options"</div><div>&gt; &gt;&gt; &gt; ----&gt; vm.start() &lt;---------- &gt; else:</div><div>&gt; &gt;&gt; &gt; print "Starting VM " + vm.name</div><div>&gt; &gt;&gt; &gt; vm.start()</div><div>&gt; &gt;&gt; &gt; while vmstat != 'down':</div><div>&gt; &gt;&gt; &gt; sleep(1)</div><div>&gt; &gt;&gt; &gt; vmstat = vm.get_status().state</div><div>&gt; &gt;&gt; &gt; except Exception, err:</div><div>&gt; &gt;&gt; &gt; print "Error on starting VM"</div><div>&gt; &gt;&gt; &gt; print err</div><div>&gt; &gt;&gt; &gt;</div><div>&gt; &gt;&gt; &gt;</div><div>&gt; &gt;&gt; &gt; Best regards</div><div>&gt; &gt;&gt; &gt; Amedeo Salvati</div><div>&gt; &gt;&gt; &gt;</div><div>&gt; &gt;&gt;</div><div>&gt; &gt;&gt; It should be something like this:</div><div>&gt; &gt;&gt;</div><div>&gt; &gt;&gt; from ovirtsdk.xml import params</div><div>&gt; &gt;&gt;</div><div>&gt; &gt;&gt; action = params.Action(</div><div>&gt; &gt;&gt; vm=params.VM(</div><div>&gt; &gt;&gt; initialization=params.Initialization(</div><div>&gt; &gt;&gt; cloud_init=params.CloudInit(</div><div>&gt; &gt;&gt; host=params.Host(</div><div>&gt; &gt;&gt; name="myvm"</div><div>&gt; &gt;&gt; ),</div><div>&gt; &gt;&gt; users=...,</div><div>&gt; &gt;&gt; files=...,</div><div>&gt; &gt;&gt; ...</div><div>&gt; &gt;&gt; )</div><div>&gt; &gt;&gt; )</div><div>&gt; &gt;&gt; )</div><div>&gt; &gt;&gt; )</div><div>&gt; &gt;&gt;</div><div>&gt; &gt;&gt; vm.start(action)</div><div>&gt; &gt;&gt;</div><div>&gt; &gt;&gt;</div><div>&gt; &gt;&gt; --</div><div>&gt; &gt;&gt; Dirección Comercial: C/Jose Bardasano Baos, 9, Edif. Gorbea 3, planta</div><div>&gt; &gt;&gt; 3ºD, 28016 Madrid, Spain</div><div>&gt; &gt;&gt; Inscrita en el Reg. Mercantil de Madrid – C.I.F. B82657941 - Red Hat S.L.</div><div>&gt; </div><div>&gt; </div><div>&gt; -- </div><div>&gt; Dirección Comercial: C/Jose Bardasano Baos, 9, Edif. Gorbea 3, planta</div><div>&gt; 3ºD, 28016 Madrid, Spain</div><div>&gt; Inscrita en el Reg. Mercantil de Madrid – C.I.F. B82657941 - Red Hat S.L.</div></div>
</div>