2013-06-02 13 views
1

OpenStack에서 미터 및 알림을 얻으려고합니다. 이 목적을 위해 Ceilometer (ceilometerclient를 통해)를 사용하고 싶습니다. 이러한 가능성을 테스트하기 위해 몇 가지 코드를 작성했습니다.OpenStack Ceilometer 클라이언트의 문제

import keystoneclient.v2_0 
import ceilometerclient.v2 as ceilometer 

class CloudMessageHandler(object): 

def __init__(self, params): 

    self._client = None 
    self._auth_data = self._get_token(params["auth"]) 
    try: 
     print "auth_data = %s" % repr(self._auth_data) 
     self._client = ceilometer.Client(endpoint=self._auth_data['endpoint'], 
             token=self._auth_data['token']) 
    except: 
     raise Exception("Can't create Ceilometer client.") 

def _get_token(self, params): 
    try: 
     ksclient = keystoneclient.v2_0.Client(username=params["username"], 
               password=params["password"], 
               tenant_id=params["tenant_id"], 
               tenant_name=params["tenant_name"], 
               auth_url=params["auth_url"]) 
     token = ksclient.auth_token 
     endpoint = ksclient.service_catalog.url_for(service_type="metering", 
                endpoint_type=params["endpoint_type"]) 
     return { "token" : token, "endpoint" : endpoint } 
    except IndexError as e: 
     raise Exception("Can't get token and endpoint through Keystone API.") 

def test(self): 
    print "meters = %s" % self._client.meters.list() 
    print "resources = %s" % self._client.resources.list() 
    print "alarms = %s" % self._client.alarms.list() 

출력 내가 얻을 :

auth_data = {'token': u'xxx', 'endpoint': u'http://ip:port'} 
meters = [] 
resources = [] 
No handlers could be found for logger "ceilometerclient.common.http" 
Traceback (most recent call last): 
    ... 
    File "/usr/local/lib/python2.7/dist-packages/ceilometerclient/v2/alarms.py", line 53, in  list 
    return self._list(options.build_url(self._path(), q)) 
    File "/usr/local/lib/python2.7/dist-packages/ceilometerclient/common/base.py", line 57, in _list 
    resp, body = self.api.json_request('GET', url) 
    File "/usr/local/lib/python2.7/dist-packages/ceilometerclient/common/http.py", line 182, in json_request 
    resp, body_iter = self._http_request(url, method, **kwargs) 
    File "/usr/local/lib/python2.7/dist-packages/ceilometerclient/common/http.py", line 165, in _http_request 
    raise exc.from_response(resp) 
ceilometerclient.exc.HTTPNotFound: HTTPNotFound (HTTP 404) 

문제점은 무엇입니까? 또한 알람을 생성 할 수 없습니다. Ceilometer 클라이언트를 통해 인스턴스 (실행/종료 이벤트)에 대한 알림을 얻을 수있는 방법을 보여주는 사람이 있습니까?

답변

1

내가 디버그 수평선 시도,

from ceilometerclient.v2 import Client as ceil_client 
from keystoneclient.v2_0.client import Client as KC 


def get_token(): 
    kc = KC(username="admin", password="111111", tenant_name="admin", auth_url="http://192.168.176.101:5000/v2.0") 
    token = kc.service_catalog.catalog['token']['id'] 
    return token 

ceil = ceil_client(endpoint='http://XXX.XXX.XXX.:8777', token=get_token) 
의미가 있습니다

! 지평선 사용 끝점 포트는 8777입니다. 사용하지 않은 것을 모른다면 도움이 될 것입니다.