887b275781
Change-Id: If90bd989767f83afdae83da61347f506e727ba72
91 lines
2.7 KiB
Python
91 lines
2.7 KiB
Python
# Copyright (c) 2014 Hewlett-Packard Development Company, L.P.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
# implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
""" An example using monascaclient via the Python API """
|
|
|
|
from monascaclient import client
|
|
import monascaclient.exc as exc
|
|
import time
|
|
|
|
# In order to use the python api directly, you must first obtain an
|
|
# auth token and identify which endpoint you wish to speak to.
|
|
endpoint = 'http://192.168.10.4:8080/v2.0'
|
|
|
|
# The api version of monasca-api
|
|
api_version = '2_0'
|
|
|
|
# There are other kwarg options (ca files) used for http request.
|
|
# Refer to monascaclient.shell.py for other kwargs supported.
|
|
kwargs = {}
|
|
|
|
kwargs['token'] = 'Mehi789blahblahblah'
|
|
# construct the monasca client
|
|
monasca_client = client.Client(api_version, endpoint, **kwargs)
|
|
|
|
# simulating token expired, call replace_token after initial construction
|
|
token = '172ebe22ec204257a958409e333b1695'
|
|
monasca_client.replace_token(token)
|
|
|
|
# you can reference the monascaclient.v2_0.shell.py
|
|
# do_commands for command fields
|
|
|
|
# post a metric
|
|
dimensions = {'instance_id': '12345', 'service': 'nova'}
|
|
fields = {}
|
|
fields['name'] = 'metric1'
|
|
fields['dimensions'] = dimensions
|
|
fields['timestamp'] = time.time()
|
|
fields['value'] = 222.333
|
|
try:
|
|
resp = monasca_client.metrics.create(**fields)
|
|
except exc.HTTPException as he:
|
|
print('HTTPException code=%s message=%s' % (he.code, he.message))
|
|
else:
|
|
print(resp)
|
|
print('Successfully created metric')
|
|
|
|
# post a metric with a unicode service name
|
|
dimensions = {'instance_id': '12345', 'service': u'\u76db\u5927'}
|
|
fields = {}
|
|
fields['name'] = 'metric1'
|
|
fields['dimensions'] = dimensions
|
|
fields['timestamp'] = time.time()
|
|
fields['value'] = 222.333
|
|
try:
|
|
resp = monasca_client.metrics.create(**fields)
|
|
except exc.HTTPException as he:
|
|
print('HTTPException code=%s message=%s' % (he.code, he.message))
|
|
else:
|
|
print(resp)
|
|
print('Successfully created metric')
|
|
|
|
print ('Giving the DB time to update...')
|
|
time.sleep(10)
|
|
|
|
# metric-list
|
|
name = 'metric1'
|
|
dimensions = None
|
|
fields = {}
|
|
if name:
|
|
fields['name'] = name
|
|
if dimensions:
|
|
fields['dimensions'] = dimensions
|
|
try:
|
|
body = monasca_client.metrics.list(**fields)
|
|
except exc.HTTPException as he:
|
|
print('HTTPException code=%s message=%s' % (he.code, he.message))
|
|
else:
|
|
print(body)
|