<div dir="ltr">Just make sure you are not changing anything that might cause a splitbrain between the engine database and the actual image set on the storage, those are usually tricky to debug and fix</div><div class="gmail_extra">
<br><br><div class="gmail_quote">On Thu, Dec 12, 2013 at 4:32 AM, Исаев Виталий Анатольевич <span dir="ltr">&lt;<a href="mailto:isaev@fintech.ru" target="_blank">isaev@fintech.ru</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">






<div lang="RU" link="blue" vlink="purple">
<div>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d">Dan, thank you for a nice advice.  I have forgotten about domxml rich opportunities…<u></u><u></u></span></p>
<div class="im">
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d">Vitaly Isaev<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:gray">Software engineer<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:gray">Information security department<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:gray">Fintech JSC, Moscow, Russia<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d"><u></u> <u></u></span></p>
</div><p class="MsoNormal"><b><span style="font-size:10.0pt;font-family:&quot;Tahoma&quot;,&quot;sans-serif&quot;">From:</span></b><span style="font-size:10.0pt;font-family:&quot;Tahoma&quot;,&quot;sans-serif&quot;"> Dan Yasny [mailto:<a href="mailto:dyasny@gmail.com" target="_blank">dyasny@gmail.com</a>]
<br>
<b>Sent:</b> Monday, December 09, 2013 8:14 PM</span></p><div><div class="h5"><br>
<b>To:</b> Исаев Виталий Анатольевич<br>
<b>Cc:</b> <a href="mailto:users@ovirt.org" target="_blank">users@ovirt.org</a><br>
<b>Subject:</b> Re: [Users] oVirt Python SDK: getting the full filenames of disk images<u></u><u></u></div></div><p></p><div><div class="h5">
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<p class="MsoNormal">Please see reply inline<u></u><u></u></p>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><u></u> <u></u></p>
<div>
<p class="MsoNormal">On Mon, Dec 9, 2013 at 12:03 AM, Исаев Виталий Анатольевич &lt;<a href="mailto:isaev@fintech.ru" target="_blank">isaev@fintech.ru</a>&gt; wrote:<u></u><u></u></p>
<div>
<div>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d">Hi Dan, glad to meet you both on LOR and in this mailing list :)</span><u></u><u></u></p>

</div>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">I know, I&#39;m everywhere :)<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0cm 0cm 0cm 6.0pt;margin-left:4.8pt;margin-right:0cm">
<div>
<div>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d"> </span><u></u><u></u></p>
<p><span lang="EN-US">Unfortunately ovirtsdk.infrastructure.brokers.&lt;anything&gt; classes instances miss information about the higher objects very often. The typical situation is returning of empty string when we ask something about the parent from the child object
 (&quot;child&quot; and &quot;parent&quot; in terms Red Hat Enterprise Virtualization objects hierarchy). Consider this Python code:</span><u></u><u></u></p>
<p><span lang="EN-US"> </span><u></u><u></u></p>
<p><span lang="EN-US">                from ovirtsdk.api import API</span><u></u><u></u></p>
<p><span lang="EN-US">                from ovirtsdk.xml import params</span><u></u><u></u></p>
<p><span lang="EN-US">                ...</span><u></u><u></u></p>
<p><span lang="EN-US">                api = API(...)</span><u></u><u></u></p>
<p><span lang="EN-US">                d = api.vms.list()[i].get_disks().list()[i]                                                 # ovirtsdk.infrastructure.brokers.VMDisk class instance, i – any number in range(api.vms.list().__len__())</span><u></u><u></u></p>

<p><span lang="EN-US">                s = d.get_storage_domains().get_storage_domain()[0]              # ovirtsdk.infrastructure.params.StorageDomain class instance</span><u></u><u></u></p>
<p><span lang="EN-US">                t = s.get_data_center()                                                                              # NoneType</span><u></u><u></u></p>
<p><span lang="EN-US"> </span><u></u><u></u></p>
<p><span lang="EN-US">So you can see that this approach does not work here. </span>
<u></u><u></u></p>
<p><span lang="EN-US"> </span><u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">I hope Michael or Itamar can shed some more light on this part, I don&#39;t have a system in front of me to check. AFAIR some objects aren&#39;t linked directly and you simply need to know how to get to them, I&#39;ve had plenty of help from Michael
 before, when I was running a seemingly correct script, and getting no data, simply because I didn&#39;t understand the way the API looks for objects and relationships.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0cm 0cm 0cm 6.0pt;margin-left:4.8pt;margin-right:0cm">
<div>
<div>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d">Our purpose is checking the VM’s disk image integrity (I mean integrity of system files,
 stored in /boot, /bin, /sbin, /lib etc.) every time the VM starts. The integrity checking script is written in Python and relies on libguestfs and vdsm hooks. Specific vdsm hook runs our script and block the VM’s boot process until the correctness of the system
 files hash sums will be checked. But libguestfs requires the full path to the disk to be handled, and it’s not integrated with ovirt infrastructure. And here we face with a task of full disk image filenames definition.</span><u></u><u></u></p>

</div>
</div>
</blockquote>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">I assume you are using before_vm_start? This will catch the VM definitions, as passed by the engine, and allow you to reassemble the domxml. You can get the disk path from the domxml directly, bypassing the engine APIs completely. <u></u><u></u></p>

</div>
<div>
<p class="MsoNormal">The problem however, if you are doing this on block storage, is that the right LV will not be prepared for use by vdsm at this point, so you&#39;ll have to make it accessible manually, then disable access and let vdsm do it&#39;s job. Much easier
 with NFS/Gluster of course.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0cm 0cm 0cm 6.0pt;margin-left:4.8pt;margin-right:0cm">
<div>
<div>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d">Thank you,</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d">Vitaly Isaev</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:gray">Software engineer</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:gray">Information security department</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:gray">Fintech JSC, Moscow, Russia</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:&quot;Calibri&quot;,&quot;sans-serif&quot;;color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Tahoma&quot;,&quot;sans-serif&quot;">From:</span></b><span lang="EN-US" style="font-size:10.0pt;font-family:&quot;Tahoma&quot;,&quot;sans-serif&quot;"> Dan
 Yasny [mailto:<a href="mailto:dyasny" target="_blank">dyasny</a></span><span style="font-size:10.0pt;font-family:&quot;Tahoma&quot;,&quot;sans-serif&quot;">@<a href="http://gmail.com" target="_blank">gmail.com</a>]
<br>
<b>Sent:</b> Friday, December 06, 2013 8:56 PM<br>
<b>To:</b> Исаев Виталий Анатольевич<br>
<b>Cc:</b> <a href="mailto:users@ovirt.org" target="_blank">users@ovirt.org</a><br>
<b>Subject:</b> Re: [Users] oVirt Python SDK: getting the full filenames of disk images</span><u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
<div>
<p class="MsoNormal">Probably not, but you can <u></u><u></u></p>
<div>
<p class="MsoNormal">- get the disk image UUID (that&#39;s the name in the filesystem or LV name), <u></u><u></u></p>
<div>
<p class="MsoNormal">- get the UUID of the storage domain (that will be the top level dir name or VG name) <u></u><u></u></p>
</div>
</div>
<div>
<p class="MsoNormal">- get the DC UUID (this will be the top level dir name and the mount point for LVM)<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Then compose the path out of these. Keep in mind that the disk UUID you get is the latest leaf in a snapshot tree, and if you need the entire chain of images, you need to recursively
 traverse the tree starting at the leaf, using the PUUID tag to find the parent.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Might be a better way, but I&#39;m not aware of it.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Moreover, if you explain why you need to touch those images manually instead of letting ovirt handle everything, we might be able to suggest a better way<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">--<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">D<u></u><u></u></p>
</div>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"> <u></u><u></u></p>
<div>
<p class="MsoNormal">On Wed, Dec 4, 2013 at 2:34 AM, Исаев Виталий Анатольевич &lt;<a href="mailto:isaev@fintech.ru" target="_blank">isaev@fintech.ru</a>&gt; wrote:<u></u><u></u></p>
<div>
<div>
<p class="MsoNormal"><span lang="EN-US">Dear ovirt-engine users,
</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US">I will be appreciated if someone experienced in oVirt Python SDK could advice the method of getting the full filename of the VM’s disk images in the RHEV hypervisor’s
 file system. Can I get filename with a full file system path from a ovirtsdk.infrastructure.brokers.VMDisk class instance?</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US">If Python SDK (what is preffered) can’t provide such an information, may be it is still possible with RHEV-M REST API?</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US">Thank you,
</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt">Vitaly Isaev</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;color:gray">Software engineer</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;color:gray">Information security department</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;color:gray">Fintech JSC, Moscow, Russia</span><u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
</div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><br>
_______________________________________________<br>
Users mailing list<br>
<a href="mailto:Users@ovirt.org" target="_blank">Users@ovirt.org</a><br>
<a href="http://lists.ovirt.org/mailman/listinfo/users" target="_blank">http://lists.ovirt.org/mailman/listinfo/users</a><u></u><u></u></p>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
</div>
</div>
</blockquote>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
</div>
</div></div></div>
</div>

</blockquote></div><br></div>