<div dir="ltr"><div><div><div>Hi Juan,<br><br></div>Also, i tried the following custom script from the ovirt panel and its working <br><br>#cloud-config<br>write_files:<br>    -content: |<br>        # THIS IS MY TEXT FILE<br>        Some Content for my file <br>    path: /tmp/myfile<br>    permissions: &#39;0644&#39; <br><br><br></div>but the same content script i tried from the ovir api call  like<br><br>&lt;custom_script&gt;#cloud-config<br>write_files:<br>    -content: |<br>        # THIS IS MY TEXT FILE<br>        Some Content for my file<br>    path: /tmp/myfile<br>    permissions: &#39;0644&#39; &lt;/custom_script&gt;<br>   &lt;/initialization&gt;<br><br></div>But its not working, may be this is a bug in the  ovirt api function call ?<br><div><div><br></div></div></div><div class="gmail_extra"><br clear="all"><div><div dir="ltr"><span>-- <br></span>Regards
<br>Shanil
</div></div>
<br><div class="gmail_quote">On Thu, Sep 11, 2014 at 3:36 PM, Shanil S <span dir="ltr">&lt;<a href="mailto:xielesshanil@gmail.com" target="_blank">xielesshanil@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>Hi Juan,<br><br></div>Okay sure..<br>The following xml i used<br><br>&lt;action&gt;<br>        &lt;vm&gt;<br>            &lt;os&gt;<br>                &lt;boot dev=&#39;cdrom&#39;/&gt;                <br>            &lt;/os&gt;<br>            &lt;initialization&gt;<br>     &lt;cloud_init&gt;<br>     &lt;host&gt;<br>         &lt;address&gt;test2&lt;/address&gt;<span class=""><br>       &lt;/host&gt;<br>       <br>      &lt;users&gt;<br>         &lt;user&gt;<br>           &lt;user_name&gt;root&lt;/user_name&gt;<br></span>           &lt;password&gt;test&lt;/password&gt;<span class=""><br>         &lt;/user&gt;<br>       &lt;/users&gt;<br>      &lt;network_configuration&gt;<br>      &lt;nics&gt;    <br>             <br>           &lt;nic&gt;<br></span>                &lt;interface&gt;virtio&lt;/interface&gt; <br>             &lt;name&gt;eth0&lt;/name&gt;<br>             &lt;boot_protocol&gt;none&lt;/boot_protocol&gt;<span class=""><br>             &lt;on_boot&gt;true&lt;/on_boot&gt;<br>           &lt;/nic&gt;<br>         &lt;/nics&gt;<br>         &lt;dns&gt;<br>           &lt;servers&gt;<br>             &lt;host&gt;<br></span>               &lt;address&gt;x.x.x.x&lt;/address&gt;<br>             &lt;/host&gt;<br>           &lt;/servers&gt;<br>         &lt;/dns&gt;<br>       &lt;/network_configuration&gt;<br>     &lt;/cloud_init&gt;<br>    &lt;custom_script&gt; #cloud-config<br><br>phone_home:<br>url: <a href="http://x.x.com/api/xx/api_receive.php" target="_blank">http://x.x.com/api/xx/api_receive.php</a><br><br>&lt;/custom_script&gt;<br>   &lt;/initialization&gt;<br>        &lt;/vm&gt;<br>    &lt;/action&gt;<span class="HOEnZb"><font color="#888888"><br><br><br></font></span></div><div class="gmail_extra"><span class="HOEnZb"><font color="#888888"><br clear="all"><div><div dir="ltr"><span>-- <br></span>Regards
<br>Shanil
</div></div></font></span><div><div class="h5">
<br><div class="gmail_quote">On Thu, Sep 11, 2014 at 1:48 PM, Juan Hernandez <span dir="ltr">&lt;<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>On 09/11/2014 06:54 AM, Shanil S wrote:<br>
&gt; Hi Juan,<br>
&gt;<br>
</span><div><div>&gt; It seems the it doesn&#39;t contains the &quot;phone_home &quot; section in the  cat<br>
&gt; /mnt/openstack/latest/user_data<br>
&gt;<br>
&gt; the following is the output<br>
&gt;<br>
&gt; #cloud-config<br>
&gt; ssh_pwauth: true<br>
&gt; disable_root: 0<br>
&gt; output:<br>
&gt;   all: &#39;&gt;&gt; /var/log/cloud-init-output.log&#39;<br>
&gt; user: root<br>
&gt; password: admin123<br>
&gt; chpasswd:<br>
&gt;   expire: false<br>
&gt; runcmd:<br>
&gt; - &#39;sed -i &#39;&#39;/^datasource_list: /d&#39;&#39; /etc/cloud/cloud.cfg; echo<br>
&gt; &#39;&#39;datasource_list:<br>
&gt;   [&quot;NoCloud&quot;, &quot;ConfigDrive&quot;]&#39;&#39; &gt;&gt; /etc/cloud/cloud.cfg&#39;<br>
&gt;<br>
&gt;<br>
&gt; but if i try with the<br>
&gt;<br>
&gt; &lt;files&gt;<br>
&gt;           &lt;file&gt;<br>
&gt;             &lt;name&gt;ignored&lt;/name&gt;<br>
&gt;             &lt;content&gt;&lt;![CDATA[runcmd:<br>
&gt;  - echo &#39;Test script !&#39; &gt; /iwashere_test.txt<br>
&gt; ]]&gt;&lt;/content&gt;<br>
&gt;             &lt;type&gt;plaintext&lt;/type&gt;<br>
&gt;           &lt;/file&gt;<br>
&gt;         &lt;/files&gt;<br>
&gt;<br>
&gt; then it will create the /iwashere_test.txt and write the contents and in<br>
&gt; that time the cat /mnt/openstack/latest/user_data is<br>
&gt;<br>
&gt; cat /mnt/openstack/latest/user_data<br>
&gt; #cloud-config<br>
&gt; ssh_pwauth: true<br>
&gt; disable_root: 0<br>
&gt; output:<br>
&gt;   all: &#39;&gt;&gt; /var/log/cloud-init-output.log&#39;<br>
&gt; user: root<br>
&gt; password: admin123<br>
&gt; chpasswd:<br>
&gt;   expire: false<br>
&gt; runcmd:<br>
&gt; - &#39;sed -i &#39;&#39;/^datasource_list: /d&#39;&#39; /etc/cloud/cloud.cfg; echo<br>
&gt; &#39;&#39;datasource_list:<br>
&gt;   [&quot;NoCloud&quot;, &quot;ConfigDrive&quot;]&#39;&#39; &gt;&gt; /etc/cloud/cloud.cfg&#39;<br>
&gt; runcmd:<br>
&gt;  - echo &#39;Test script !&#39; &gt; /iwashere_test.txt<br>
&gt;<br>
&gt; so, i think the custom script section is not working, i am attaching the<br>
&gt; vm log as a screenshot.<br>
&gt;<br>
<br>
</div></div>Can you share the XML document that you sent to the RESTAPI in order to<br>
populate the &quot;phone_home&quot; section?<br>
<span><br>
&gt; On Wed, Sep 10, 2014 at 2:07 PM, Juan Hernandez &lt;<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a><br>
</span><div><div>&gt; &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;&gt; wrote:<br>
&gt;<br>
&gt;     On 09/10/2014 06:44 AM, Shanil S wrote:<br>
&gt;     &gt; Hi Juan,<br>
&gt;     &gt;<br>
&gt;     &gt; What i am planning to do is to make work the following script<br>
&gt;     &gt;<br>
&gt;     &gt; #cloud-config<br>
&gt;     &gt;<br>
&gt;     &gt; # phone_home: if this dictionary is present, then the phone_home<br>
&gt;     &gt; # cloud-config module will post specified data back to the given<br>
&gt;     &gt; # url<br>
&gt;     &gt; # default: none<br>
&gt;     &gt; # phone_home:<br>
&gt;     &gt; #  url: <a href="http://my.foo.bar/$INSTANCE/" target="_blank">http://my.foo.bar/$INSTANCE/</a><br>
&gt;     &gt; #  post: all<br>
&gt;     &gt; #  tries: 10<br>
&gt;     &gt; #<br>
&gt;     &gt; phone_home:<br>
&gt;     &gt;  url: <a href="http://my.example.com/$INSTANCE_ID/" target="_blank">http://my.example.com/$INSTANCE_ID/</a><br>
&gt;     &gt;  post: [ pub_key_dsa, pub_key_rsa, pub_key_ecdsa, instance_id ]<br>
&gt;     &gt;<br>
&gt;     &gt; (<a href="http://cloudinit.readthedocs.org/en/latest/topics/examples.html#run-commands-on-first-boot" target="_blank">http://cloudinit.readthedocs.org/en/latest/topics/examples.html#run-commands-on-first-boot</a>)<br>
&gt;     &gt;<br>
&gt;     &gt; but it wasn&#39;t working when i tried, i hope to post the above values to<br>
&gt;     &gt; the specific url and get the posted details.<br>
&gt;     &gt;<br>
&gt;<br>
&gt;     I think it should work, but it depends completely on cloud-init itself.<br>
&gt;     I&#39;d suggest you check the content of the generated cloud-init<br>
&gt;     configuration file (as described in a previous mail). If it contains the<br>
&gt;     &quot;phone_home&quot; section then you can discard a problem with oVirt, and<br>
&gt;     focus on clud-init.<br>
&gt;<br>
&gt;     &gt;<br>
&gt;     &gt; On Wed, Sep 10, 2014 at 10:02 AM, Shanil S &lt;<a href="mailto:xielesshanil@gmail.com" target="_blank">xielesshanil@gmail.com</a> &lt;mailto:<a href="mailto:xielesshanil@gmail.com" target="_blank">xielesshanil@gmail.com</a>&gt;<br>
</div></div><span>&gt;     &gt; &lt;mailto:<a href="mailto:xielesshanil@gmail.com" target="_blank">xielesshanil@gmail.com</a> &lt;mailto:<a href="mailto:xielesshanil@gmail.com" target="_blank">xielesshanil@gmail.com</a>&gt;&gt;&gt; wrote:<br>
&gt;     &gt;<br>
&gt;     &gt;     Hi Juan,<br>
&gt;     &gt;<br>
&gt;     &gt;     Okay.. Thanks.. its working.<br>
&gt;     &gt;<br>
&gt;     &gt;     I would like to execute other page something like test_script.php by<br>
&gt;     &gt;     posting some values to it using the cloud init, Is it possible to do<br>
&gt;     &gt;     it ?<br>
&gt;     &gt;<br>
&gt;     &gt;<br>
&gt;     &gt;<br>
&gt;     &gt;     --<br>
&gt;     &gt;     Regards<br>
&gt;     &gt;     Shanil<br>
&gt;     &gt;<br>
&gt;     &gt;     On Fri, Sep 5, 2014 at 10:08 PM, Juan Hernandez &lt;<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a> &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;<br>
</span><div><div>&gt;     &gt;     &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a> &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;&gt;&gt; wrote:<br>
&gt;     &gt;<br>
&gt;     &gt;         On 09/05/2014 12:55 PM, Shanil S wrote:<br>
&gt;     &gt;         &gt; Hi Juan,<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;         &gt; Thanks for your reply.<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;         &gt; I tried with the above but i was unable to find the<br>
&gt;     &#39;iwashere.txt&#39; after<br>
&gt;     &gt;         &gt; executing the above xml.<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;<br>
&gt;     &gt;         I repeated the test, this time with 3.4, and it worked<br>
&gt;     fine for<br>
&gt;     &gt;         me. As<br>
&gt;     &gt;         the formatting of the XML is very important I&#39;d suggest<br>
&gt;     that you<br>
&gt;     &gt;         take<br>
&gt;     &gt;         the attached script (instead of copy &amp; paste from the mail),<br>
&gt;     &gt;         change the<br>
&gt;     &gt;         password and VM id and run it.<br>
&gt;     &gt;<br>
&gt;     &gt;         There are two kind of things that can go wrong here. One<br>
&gt;     is that the<br>
&gt;     &gt;         engine/VDSM combination may not be generating the right<br>
&gt;     file. To<br>
&gt;     &gt;         verify<br>
&gt;     &gt;         this start the VM with the attached script, and once it is<br>
&gt;     &gt;         started go to<br>
&gt;     &gt;         the hypervisor where it is running and find the corresponding<br>
&gt;     &gt;         qemu process:<br>
&gt;     &gt;<br>
&gt;     &gt;           # ps -ef | grep -- &#39;-name myvm&#39;<br>
&gt;     &gt;<br>
&gt;     &gt;         This will give you a very long command line. That command line<br>
&gt;     &gt;         should<br>
&gt;     &gt;         include a &quot;-drive&quot; option containing the full path of the<br>
&gt;     disk image<br>
&gt;     &gt;         generated by the engine/VDSM, something like this:<br>
&gt;     &gt;<br>
&gt;     &gt;           -drive<br>
&gt;     &gt;<br>
&gt;      file=/var/run/vdsm/payload/b5f087d4-022d-4d5f-8a1e-268c562c7bb1.b6fcddff571bb8c2028c61b623d172a6.img<br>
&gt;     &gt;<br>
&gt;     &gt;         To inspect its content make a copy (just in case) and<br>
&gt;     mount it:<br>
&gt;     &gt;<br>
&gt;     &gt;           # cp -drive<br>
&gt;     &gt;<br>
&gt;      file=/var/run/vdsm/payload/b5f087d4-022d-4d5f-8a1e-268c562c7bb1.b6fcddff571bb8c2028c61b623d172a6.img<br>
&gt;     &gt;         /root/my.img<br>
&gt;     &gt;           # mount -o loop,ro /root/my.img /mnt<br>
&gt;     &gt;<br>
&gt;     &gt;         Inspect the content:<br>
&gt;     &gt;<br>
&gt;     &gt;           # find /mnt<br>
&gt;     &gt;           /mnt/openstack<br>
&gt;     &gt;           /mnt/openstack/content<br>
&gt;     &gt;           /mnt/openstack/content/0000<br>
&gt;     &gt;           /mnt/openstack/latest<br>
&gt;     &gt;           /mnt/openstack/latest/meta_data.json<br>
&gt;     &gt;           /mnt/openstack/latest/user_data<br>
&gt;     &gt;<br>
&gt;     &gt;         The content of the custom-script should be at the end of the<br>
&gt;     &gt;         &quot;user_data&quot;<br>
&gt;     &gt;         file, so take a look at that:<br>
&gt;     &gt;<br>
&gt;     &gt;           # cat /mnt/openstack/latest/user_data<br>
&gt;     &gt;           #cloud-config<br>
&gt;     &gt;           ssh_pwauth: true<br>
&gt;     &gt;           disable_root: 0<br>
&gt;     &gt;           output:<br>
&gt;     &gt;             all: &#39;&gt;&gt; /var/log/cloud-init-output.log&#39;<br>
&gt;     &gt;           user: root<br>
&gt;     &gt;           password: mypassword<br>
&gt;     &gt;           chpasswd:<br>
&gt;     &gt;             expire: false<br>
&gt;     &gt;           runcmd:<br>
&gt;     &gt;           - &#39;sed -i &#39;&#39;/^datasource_list: /d&#39;&#39;<br>
&gt;     /etc/cloud/cloud.cfg; echo<br>
&gt;     &gt;         &#39;&#39;datasource_list:<br>
&gt;     &gt;             [&quot;NoCloud&quot;, &quot;ConfigDrive&quot;]&#39;&#39; &gt;&gt; /etc/cloud/cloud.cfg&#39;<br>
&gt;     &gt;           runcmd:<br>
&gt;     &gt;            - echo &quot;I was here!&quot; &gt; /iwashere.txt<br>
&gt;     &gt;<br>
&gt;     &gt;         If your custom script isn&#39;t there then there is some<br>
&gt;     problem in the<br>
&gt;     &gt;         engine/VDSM side, otherwise the problem is probably in<br>
&gt;     cloud-init<br>
&gt;     &gt;         itself, and we will need someone with more knowledge of<br>
&gt;     &gt;         cloud-init to<br>
&gt;     &gt;         debug it.<br>
&gt;     &gt;<br>
&gt;     &gt;         Don&#39;t forget to umount the file when finished:<br>
&gt;     &gt;<br>
&gt;     &gt;           # umount /mnt<br>
&gt;     &gt;<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;         &gt; On Fri, Sep 5, 2014 at 3:00 PM, Juan Hernandez<br>
&gt;     &lt;<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a> &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;<br>
&gt;     &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a> &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;&gt;<br>
&gt;     &gt;         &gt; &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a> &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;<br>
&gt;     &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a> &lt;mailto:<a href="mailto:jhernand@redhat.com" target="_blank">jhernand@redhat.com</a>&gt;&gt;&gt;&gt; wrote:<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;         &gt;     On 09/05/2014 10:46 AM, Sven Kieske wrote:<br>
&gt;     &gt;         &gt;     &gt;<br>
&gt;     &gt;         &gt;     &gt;<br>
&gt;     &gt;         &gt;     &gt; Am 05.09.2014 10:27, schrieb Juan Hernandez:<br>
&gt;     &gt;         &gt;     &gt;&gt; Trying to make an example for this I discovered that<br>
&gt;     &gt;         the &quot;custom_script&quot;<br>
&gt;     &gt;         &gt;     &gt;&gt; element is currently ignored if the &quot;cloud_init&quot;<br>
&gt;     &gt;         element is present.<br>
&gt;     &gt;         &gt;     &gt;&gt; Instead we are taking the content of the first &quot;file&quot;<br>
&gt;     &gt;         element from the<br>
&gt;     &gt;         &gt;     &gt;&gt; &quot;cloud_init&quot; element and appending it to the<br>
&gt;     cloud-init<br>
&gt;     &gt;         configuration<br>
&gt;     &gt;         &gt;     &gt;&gt; file. I believe that this is a bug, as it breaks<br>
&gt;     &gt;         backwards compatibility:<br>
&gt;     &gt;         &gt;     &gt;&gt;<br>
&gt;     &gt;         &gt;     &gt;&gt;   <a href="https://bugzilla.redhat.com/1138564" target="_blank">https://bugzilla.redhat.com/1138564</a><br>
&gt;     &gt;         &gt;     &gt;<br>
&gt;     &gt;         &gt;     &gt; Thanks for the report, I just proposed this as a<br>
&gt;     blocker<br>
&gt;     &gt;         for the 3.4.4<br>
&gt;     &gt;         &gt;     &gt; release as it is a clear regression.<br>
&gt;     &gt;         &gt;     &gt; Also I rely on this functionality in my 3.3. setup<br>
&gt;     and I<br>
&gt;     &gt;         want to upgrade<br>
&gt;     &gt;         &gt;     &gt; to 3.4 so I can&#39;t upgrade until this is fixed and<br>
&gt;     released.<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;         &gt;     Agree, I set the bug as a blocker for 3.4.4.<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;         &gt;     &gt;&gt;<br>
&gt;     &gt;         &gt;     &gt;&gt; However, you can exploit this bug to do what you<br>
&gt;     want.<br>
&gt;     &gt;         This is an example:<br>
&gt;     &gt;         &gt;     &gt;<br>
&gt;     &gt;         &gt;     &gt; Well I guess this is a pretty bad idea, because it<br>
&gt;     will<br>
&gt;     &gt;         just work<br>
&gt;     &gt;         &gt;     &gt; until the bug is fixed?<br>
&gt;     &gt;         &gt;     &gt;<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;         &gt;     No, what I proposed in the example is to put the custom<br>
&gt;     &gt;         script in both<br>
&gt;     &gt;         &gt;     the first &quot;file&quot; inside &quot;clud_init&quot; and in the<br>
&gt;     &gt;         &quot;custom_script&quot; element.<br>
&gt;     &gt;         &gt;     That should work with the current status and also<br>
&gt;     if/when<br>
&gt;     &gt;         we fix the<br>
&gt;     &gt;         &gt;     bug.<br>
&gt;     &gt;         &gt;<br>
&gt;     &gt;<br>
&gt;<br>
<br>
--<br>
Dirección Comercial: C/Jose Bardasano Baos, 9, Edif. Gorbea 3, planta<br>
3ºD, 28016 Madrid, Spain<br>
Inscrita en el Reg. Mercantil de Madrid – C.I.F. B82657941 - Red Hat S.L.<br>
</div></div></blockquote></div><br></div></div></div>
</blockquote></div><br></div>