openstack team mailing list archive
-
openstack team
-
Mailing list archive
-
Message #07045
Re: [nova client] Can't get the diagnostics command to work
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@xxxxxxxxx> 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@xxxxxxxxx> 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@xxxxxxxxx> 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@xxxxxxxxxxxx> 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@xxxxxxxxxxxxx> 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@xxxxxxxxx> 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@xxxxxxxxxxxxxxxxxxx
>>>> Unsubscribe : https://launchpad.net/~openstack
>>>> More help : https://help.launchpad.net/ListHelp
>>>>
>>>> _______________________________________________
>>>> Mailing list: https://launchpad.net/~openstack
>>>> Post to : openstack@xxxxxxxxxxxxxxxxxxx
>>>> Unsubscribe : https://launchpad.net/~openstack
>>>> More help : https://help.launchpad.net/ListHelp
>>>
>>>
>>>
>>> _______________________________________________
>>> Mailing list: https://launchpad.net/~openstack
>>> Post to : openstack@xxxxxxxxxxxxxxxxxxx
>>> Unsubscribe : https://launchpad.net/~openstack
>>> More help : https://help.launchpad.net/ListHelp
>>
>>
>>
>
>
References
-
[nova client] Can't get the diagnostics command to work
From: Leander Bessa, 2012-01-24
-
Re: [nova client] Can't get the diagnostics command to work
From: Kiall Mac Innes, 2012-01-24
-
Re: [nova client] Can't get the diagnostics command to work
From: Brian Waldon, 2012-01-24
-
Re: [nova client] Can't get the diagnostics command to work
From: Kiall Mac Innes, 2012-01-24
-
Re: [nova client] Can't get the diagnostics command to work
From: Leander Bessa, 2012-01-24
-
Re: [nova client] Can't get the diagnostics command to work
From: Vishvananda Ishaya, 2012-01-24
-
Re: [nova client] Can't get the diagnostics command to work
From: Leander Bessa, 2012-01-25
-
Re: [nova client] Can't get the diagnostics command to work
From: Leander Bessa, 2012-01-25
-
Re: [nova client] Can't get the diagnostics command to work
From: Vishvananda Ishaya, 2012-01-25
-
Re: [nova client] Can't get the diagnostics command to work
From: Leander Bessa, 2012-01-26