[Openstack] [nova client] Can't get the diagnostics command to work
Vishvananda Ishaya
vishvananda at gmail.com
Thu Jan 26 23:47:39 UTC 2012
Well the code to generate diagnostics under xen is in nova/virt/xenapi/vm_utils.py:
887 def compile_diagnostics(cls, session, record):
888 """Compile VM diagnostics data"""
889 try:
890 host = session.get_xenapi_host()
891 host_ip = session.call_xenapi("host.get_record", host)["address"]
892 except (cls.XenAPI.Failure, KeyError) as e:
893 return {"Unable to retrieve diagnostics": e}
894
895 try:
896 diags = {}
897 xml = get_rrd(host_ip, record["uuid"])
898 if xml:
899 rrd = minidom.parseString(xml)
900 for i, node in enumerate(rrd.firstChild.childNodes):
901 # We don't want all of the extra garbage
902 if i >= 3 and i <= 11:
903 ref = node.childNodes
904 # Name and Value
905 if len(ref) > 6:
906 diags[ref[0].firstChild.data] = \
907 ref[6].firstChild.data
908 return diags
909 except cls.XenAPI.Failure as e:
910 return {"Unable to retrieve diagnostics": e}
911
Example RRD is here: http://community.citrix.com/display/xs/Using+XenServer+RRDs
Perhaps someone could paste the actual data from an install running xen so we can see what the extracted data looks like?
Then it is as easy as adding a call like the following to nova/virt/libvirt/connection.py:
def get_diagnostics(self, instance_name):
# look up the domain by instance name
virt_dom = self._lookup_by_name(instance_name)
# get info from the domain using libvirt calls
# map the data into the proper dictionary format
# return the data
return diag
Vish
On Jan 26, 2012, at 2:56 AM, Leander Bessa wrote:
> Could you give me some references on how i could implement the diagnostics call for kvm/libvirt?
>
> Regards,
>
> Leander
>
> On Wed, Jan 25, 2012 at 7:39 PM, Vishvananda Ishaya <vishvananda at gmail.com> wrote:
> There are currently no plans for such of thing. It seems easier to rely on existing plugins for monitoring. That said, it shouldn't be too hard to implement the diagnostics call for kvm/libvirt if someone wants to tackle it.
>
> Vish
>
> On Jan 25, 2012, at 8:21 AM, Leander Bessa wrote:
>
>> Are there any plans to add support for monitoring instances which run libvirt? Does XEN also use libvirt?
>>
>> On Wed, Jan 25, 2012 at 2:01 PM, Leander Bessa <leanderbb at gmail.com> wrote:
>> Ok i'll look into that, thank you for the answers.
>>
>> Regards,
>>
>> Leander
>>
>>
>> On Tue, Jan 24, 2012 at 11:16 PM, Vishvananda Ishaya <vishvananda at gmail.com> wrote:
>> Monitoring can be done through libvirt monitoring plugins. For example:
>>
>> http://honk.sigxcpu.org/projects/libvirt/
>>
>> Vish
>>
>> On Jan 24, 2012, at 2:01 PM, Leander Bessa wrote:
>>
>>> How exactly do i install that particular extension and what can i use as an alternative to monitor instances with KVM?
>>>
>>>
>>> On Tue, Jan 24, 2012 at 6:11 PM, Kiall Mac Innes <kiall at managedit.ie> wrote:
>>> I've just verified this against my install, but since the diagnostics is unsupported when using libvirt/kvm, it still errors out (but with a 500, rather than 404)
>>>
>>> Thanks,
>>> Kiall
>>>
>>>
>>>
>>> On Tue, Jan 24, 2012 at 5:56 PM, Brian Waldon <brian.waldon at rackspace.com> wrote:
>>> Actually the diagnostics command was not added in Essex, but it was converted to a true extension. However it is part of the Admin API, which means for Diablo you need to set the allow_admin_api flag on your nova-api node.
>>>
>>>
>>> On Jan 24, 2012, at 9:41 AM, Kiall Mac Innes wrote:
>>>
>>>> Hi,
>>>>
>>>> The diagnostics command was added in Essex, my packages are using the stable Diablo version.
>>>>
>>>> Novaclient sadly shows these options even though they can't be used with Diablo.
>>>>
>>>> Kiall
>>>>
>>>> Sent from my mobile - Sorry for being short.
>>>>
>>>> On Jan 24, 2012 5:04 p.m., "Leander Bessa" <leanderbb at gmail.com> wrote:
>>>> Hello,
>>>>
>>>> I've setup a single node configuration with keystone using the packages from https://launchpad.net/~managedit/+archive/openstack.
>>>>
>>>> I've managed to launch an instance, however when i run the commando nova diagnostics <server> i get this:
>>>>
>>>> REQ: curl -i http://127.0.0.1:5000/tokens -X POST -H "Content-Type: application/json" -H "User-Agent: python-novaclient"
>>>>
>>>> REQ BODY: {"auth": {"tenantName": "admin", "passwordCredentials": {"username": "admin", "password": "admin"}}}
>>>>
>>>> RESP:{'date': 'Tue, 24 Jan 2012 16:56:24 GMT', 'status': '200', 'content-length': '1119', 'content-type': 'application/json; charset=UTF-8'} {"access": {"token": {"expires": "2015-02-05T00:00:00", "id": "999888777666", "tenant": {"id": "1", "name": "admin"}}, "serviceCatalog": [{"endpoints": [{"adminURL": "http://127.0.0.1:8774/v1.1/1", "region": "RegionOne", "internalURL": "http://127.0.0.1:8774/v1.1/1", "publicURL": "http://127.0.0.1:8774/v1.1/1"}], "type": "compute", "name": "nova"}, {"endpoints": [{"adminURL": "http://127.0.0.1:8774/v1.0", "region": "RegionOne", "internalURL": "http://127.0.0.1:8774/v1.0", "publicURL": "http://127.0.0.1:8774/v1.0/"}], "type": "compute", "name": "nova_compat"}, {"endpoints": [{"adminURL": "http://127.0.0.1:9292/v1.1/1", "region": "RegionOne", "internalURL": "http://127.0.0.1:9292/v1.1/1", "publicURL": "http://127.0.0.1:9292/v1.1/1"}], "type": "image", "name": "glance"}, {"endpoints": [{"adminURL": "http://127.0.0.1:35357/v2.0", "region": "RegionOne", "internalURL": "http://127.0.0.1:5000/v2.0", "publicURL": "http://127.0.0.1:5000/v2.0"}], "type": "identity", "name": "identity"}], "user": {"id": "1", "roles": [{"tenantId": "1", "id": "1", "name": "Admin"}, {"id": "1", "name": "Admin"}], "name": "admin"}}}
>>>>
>>>> REQ: curl -i http://127.0.0.1:8774/v1.1/1/servers/3/diagnostics -X GET -H "X-Auth-Project-Id: admin" -H "User-Agent: python-novaclient" -H "X-Auth-Token: 999888777666"
>>>>
>>>> REQ: curl -i http://127.0.0.1:8774/v1.1/1/servers/3/diagnostics -X GET -H "X-Auth-Project-Id: admin" -H "User-Agent: python-novaclient" -H "X-Auth-Token: 999888777666"
>>>>
>>>> RESP:{'date': 'Tue, 24 Jan 2012 16:56:24 GMT', 'status': '404', 'content-length': '52', 'content-type': 'text/plain; charset=UTF-8'} 404 Not Found
>>>>
>>>> The resource could not be found.
>>>>
>>>>
>>>>
>>>> RESP:{'date': 'Tue, 24 Jan 2012 16:56:24 GMT', 'status': '404', 'content-length': '52', 'content-type': 'text/plain; charset=UTF-8'} 404 Not Found
>>>>
>>>> The resource could not be found.
>>>>
>>>>
>>>> n/a (HTTP 404)
>>>>
>>>>
>>>> Any ideas?
>>>>
>>>> Regards,
>>>>
>>>> Leander
>>>>
>>>> _______________________________________________
>>>> Mailing list: https://launchpad.net/~openstack
>>>> Post to : openstack at lists.launchpad.net
>>>> Unsubscribe : https://launchpad.net/~openstack
>>>> More help : https://help.launchpad.net/ListHelp
>>>>
>>>> _______________________________________________
>>>> Mailing list: https://launchpad.net/~openstack
>>>> Post to : openstack at lists.launchpad.net
>>>> Unsubscribe : https://launchpad.net/~openstack
>>>> More help : https://help.launchpad.net/ListHelp
>>>
>>>
>>>
>>> _______________________________________________
>>> Mailing list: https://launchpad.net/~openstack
>>> Post to : openstack at lists.launchpad.net
>>> Unsubscribe : https://launchpad.net/~openstack
>>> More help : https://help.launchpad.net/ListHelp
>>
>>
>>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.openstack.org/pipermail/openstack/attachments/20120126/996b5dae/attachment.html>
More information about the Openstack
mailing list