[ovirt-users] Error while using REST API with Ovirt
Shahar Havivi
shaharh at redhat.com
Thu Sep 18 15:10:23 EDT 2014
On 18.09.14 15:00, Juan Hernandez wrote:
> On 09/18/2014 01:39 PM, Chandrahasa S wrote:
> > Dear Juan / All,
> >
> > Thanks for reply.
> >
> > I tried to give the hostname with the tag mentioned "host_name". Its
> > working.
> >
> > So below are the issues still remaining:
> >
> > 1) The issue of internal server error still persits (rhev
> > manager showing issues) even after following the advice of the expert
> > and doing the initialization part just once(giving ip and
> > hostname) after creating the vm.
> >
>
> Actually this is a bug:
>
> https://bugzilla.redhat.com/1144005
>
> The reason is that when you use an incorrect boot protocol we end up
> storing null in the corresponding place in the database, and later we
> use the value without checking it, which triggers a null pointer exception.
>
> The right value for the boot protocol is "static", not "STATIC_IP". The
> "STATIC_IP" value is what we use in the backend and in the database, but
> in the RESTAPI it is "static".
>
> To workaround this issue you can delete the VMs and create them again
> with the correct boot protocol.
>
> If you don't want to create the VMs again you can fix the database
> manually like this:
>
> # su - postgres
> # psql
> postgres=# \c engine
> engine=# update vm_init set networks = replace(networks, '"bootProtocol"
> : null', '"bootProtocol" : "STATIC_IP"');
>
> > 2) Please confirm if this is the case that we can do
> > initialization part only once on a particular vm , then we can
> > reconfigure the network (ip, subnet, gateway etc)
> > or not for that vm.
> >
>
> I'm reasonably sure that you can run initialization only once per VM,
> but Shahar can confirm this better than me.
Yes on RunVm we send the cloud-init params only the first time, ie when the
is_initialized flag is false in vm_static table,
You can resend the existing cloud-init params (and override them) via the
RunOnce - I believe that if you run the VM via Rest with the <initialization>
section it will run via RunOnce.
>
> > 3) For Windows guest we are still unable to provide ip details
> > and hostname using sysprep/payload.
> >
>
> I'm not familiar with Sysprep. Can you provide an example of the code
> that you are using for that?
In 3.5 we have a filed vm_hostname, regarding the IP you can provide the
Sysprep file in the Initialization/Sysprep elements (not sure that is the
right name, Juan?) - please note that if you do provide it we send the Sysprep
as is and not replace the vm_hostname and other fields that user provided.
>
> > Error attached.
> >
> >
> >
> > Regards,
> > Chandrahasa S
> >
> >
> >
> > From: Juan Hernandez <jhernand at redhat.com>
> > To: Chandrahasa S <chandrahasa.s at tcs.com>, users at ovirt.org
> > Cc: Agarwal Ruchita <agarwal.ruchita at tcs.com>
> > Date: 09/18/2014 03:35 PM
> > Subject: Re: [ovirt-users] Error while using REST API with Ovirt
> > ------------------------------------------------------------------------
> >
> >
> >
> > On 09/18/2014 08:18 AM, Chandrahasa S wrote:
> >> Dear Experts.
> >>
> >> We are Integrating our internal cloud portal with Ovirt / RHEVM version
> >> 3.4.
> >>
> >> We are integrating our internal cloud with Ovirt / RHEVM. VM template
> >> created using cloud init.
> >>
> >> Through REST API Nippet while codes passes command to template ( with
> >> cloud init) IP, HOSTNAME, We are able to set IP and Hostname to VM
> >> through code.
> >>
> >> But post this Manager getting handed. Error code is attached.
> >>
> >> Need your help please.
> >>
> >
> > If I understand correctly you already created a template with the cloud
> > init configuration, then you created a VM from that template, and you
> > want to modify it and start it. In order to update the VM you need to
> > issue a PUT request, and the tag name for the host is "host_name":
> >
> > String updateXml =
> > "<?xml version=\"1.0\"?>"
> > + "<vm>"
> > + "<initialization>"
> > + "<host_name>meghaasadmin.ultimatixuat.net</host_name>"
> > + "<regenerate_ssh_keys>false</regenerate_ssh_keys>"
> > + "<nic_configurations>"
> > + "<nic_configuration>"
> > + "<name>eth0</name>"
> > + "<ip address=\"1.1.1.1\" netmask=\"255.255.255.0\"
> > gateway=\"13.3.3.3\"/>"
> > + "<boot_protocol>static</boot_protocol>"
> > + "<on_boot>true</on_boot>"
> > + "</nic_configuration>"
> > + "</nic_configurations>"
> > + "</initialization>"
> > + "</vm>";
> > StringEntity updateEntity = new StringEntity(updateXml);
> > HttpPut updateRequest = new HttpPut(apiUrl + "/vms/" + vmId);
> > updateRequest.setHeader("Content-Type", "application/xml");
> > updateRequest.setHeader("Accept", "application/xml");
> > updateRequest.setEntity(updateEntity);
> > HttpResponse updateResponse = client.execute(updateRequest);
> >
> > Then, after the update, you need to start the VM and it will use that
> > configuration:
> >
> > String startXml =
> > "<?xml version=\"1.0\"?>"
> > + "<action/>";
> > StringEntity startEntity = new StringEntity(startXml);
> > HttpPost startRequest = new HttpPost(apiUrl + "/vms/" + vmId +
> > "/start");
> > startRequest.setEntity(startEntity);
> > startRequest.setHeader("Content-Type", "application/xml");
> > startRequest.setHeader("Accept", "application/xml");
> > HttpResponse startResponse = client.execute(startRequest);
> >
> > Some advices:
> >
> > * Check the XML schema for the structure of the XML documents:
> >
> > https://rhevmanager/api?schema
> >
> > * When sending requests to the RESTAPI makes sure to always explicitly
> > add the Content-Type and Accept headers:
> >
> > yourRequest.setHeader("Content-Type", "application/xml");
> > yourRequest.setHeader("Accept", "application/xml");
> >
> > * Take into account that the initialization with cloud-init will only be
> > executed the first time you start the VM, so in your tests you will need
> > to remove the VM and create it again.
> >
> > * If you are planning to do complex things you may find it helpful the
> > Java SDK:
> >
> > http://www.ovirt.org/Java-sdk
> >
>
> --
> Dirección Comercial: C/Jose Bardasano Baos, 9, Edif. Gorbea 3, planta
> 3ºD, 28016 Madrid, Spain
> Inscrita en el Reg. Mercantil de Madrid – C.I.F. B82657941 - Red Hat S.L.
More information about the Users
mailing list