您好,登錄后才能下訂單哦!
小編給大家分享一下OpenStack監(jiān)控測量服務(wù)Ceilometer安裝及API說明的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
1.Ceilometer是做什么的
Ceilometer是OpenStack中的一個(gè)子項(xiàng)目,它像一個(gè)漏斗一樣,能把OpenStack內(nèi)部發(fā)生 的幾乎所有的事件都收集起來,然后為計(jì)費(fèi)和監(jiān)控以及其它服務(wù)提供數(shù)據(jù)支撐。Ceilometer的核心架構(gòu)圖
2.OpenStack監(jiān)控測量服務(wù)Ceilometer安裝
2.1 到github下載最新的ceilometer代碼
2.2安裝mongodb, 由于ceilometer采用mongodb作為默認(rèn)數(shù)據(jù)持久化數(shù)據(jù)庫,所以需要先安裝mongodb
apt-get install mongodb
2.3在keystone中添加ceilometer用戶
需注意:添加的ceilometer賬戶需要屬于admin tenant否則會(huì)出現(xiàn)不能獲取實(shí)例監(jiān)控信息的情況,并且將此賬戶添加為ResellerAdmin角色中便于獲取swift監(jiān)控信息。 添加的ceilometer賬戶需要屬于admin tenant,并且角色為ResellerAdmin以及Admin。
查看user列表
keystone --os-username admin --os_password pass --os_tenant_name admin --os_auth_url http://localhost:5000/v2.0 user-list
查看role列表
keystone --os-username admin --os_password pass --os_tenant_name admin --os_auth_url http://localhost:5000/v2.0 role-list
查看tanant列表
keystone --os-username admin --os_password pass --os_tenant_name admin --os_auth_url http://localhost:5000/v2.0 tenant-list
新建user
keystone --os-username admin --os_password pass --os_tenant_name admin --os_auth_url http://localhost:5000/v2.0 user-create --name ceilometer --email co@co.cn --tenant-id tid --pass pass --enabled true
添加user角色
keystone --os-username admin --os_password pass --os_tenant_name admin --os_auth_url http://localhost:5000/v2.0 user-role-add --user-id uid --tenant-id tid --role-id rid
2.4安裝ceilometer
1)首先查看模塊所依賴的包
vim ceilometer/requirements.txt
d2to1>=0.2.10,<0.3
pbr>=0.5,<0.6
WebOb>=1.2
kombu
iso8601
argparse
SQLAlchemy>=0.7,<=0.7.99
sqlalchemy-migrate>=0.7.2
pymongo>=2.2
eventlet
anyjson>=0.2.4
Flask==0.9
pecan>=0.2.0
stevedore>=0.7
msgpack-python
python-glanceclient
python-novaclient>=2.6.10
python-keystoneclient>=0.2.3
python-swiftclient
lxml
requests>=1.1
wsme>=0.5b2
pyyaml
oslo.config>=1.1.0
happybase>=0.4
復(fù)制代碼
此版本ceilometer使用G版本Openstack中新加的oslo.config模塊完成配置文件讀取模塊。
此外要求WebOb的版本要在1.2以上,查看F版本Openstack使用的此庫版本為1.0.8,這是比較大的沖突,并且發(fā)現(xiàn)有很多人反映此庫與之前的庫不兼容的情況(https://bugs.launchpad.net/ceilometer/+bug/1092227),在我實(shí)際的安裝過程中也發(fā)現(xiàn)此庫不能被python-novaclient, python-glanceclient等庫所使用。于是我使用virtualenv(https://pypi.python.org/pypi/virtualenv)建立了一個(gè)隔離的python環(huán)境來安裝運(yùn)行ceilometer及相關(guān)依賴。
2)安裝virtualenv并建立隔離沙箱
sudo pip install virtualenv #安裝
virtualenv grizzlyenv #建立名為grizzlyenv的隔離環(huán)境
source grizzlyenv/bin/activate #進(jìn)入grizzlyenv隔離環(huán)境
進(jìn)入后在提示符前會(huì)出現(xiàn)提示,如
(grizzlyenv)root@ceilotest:/opt#
在此環(huán)境下,有一套獨(dú)立于全局python的環(huán)境,在此使用pip和easy_install安裝python包都可以不影響全局的python環(huán)境,使用完畢之后使用deactivate命令即可退出到全局環(huán)境,相關(guān)的使用方法在網(wǎng)上都可以找到,在此不贅述
3)隔離環(huán)境安裝完畢之后,就能夠在這之中安裝ceilometer了
#cd ceilometer
#python setup.py develop
安裝完之后可以看到所依賴的包都安裝在了grizzlyenv/lib/python2.7/site-packages/ 路徑之下。
將ceilometer/etc/ceilometer/下所有文件拷貝到/etc/ceilometer/目錄下(沒有則新建),并將其中ceilometer.conf.sample文件修改為:
ceilometer.conf
[DEFAULT]
verbose=True
debug=True
os_auth_url = http://192.168.5.202:35357/v2.0
os_tenant_name = admin
os_password = admin
os_username = ceilometer
policy_file = /etc/ceilometer/policy.json
notification_topics = notifications,glance_notifications
rabbit_password = admin
rabbit_host = 127.0.0.1
rabbit_max_retries = 10
rpc_backend = ceilometer.openstack.common.rpc.impl_kombu
[keystone_authtoken]
signing_dir = /etc/ceilometer
admin_tenant_name = admin
admin_password = admin
admin_user = ceilometer
auth_protocol = http
復(fù)制代碼
4) 啟動(dòng)ceilometer
在screen中開啟四個(gè)選項(xiàng)卡,依次運(yùn)行:
ceilometer-collector
ceilometer-agent-central
ceilometer-agent-compute
ceilometer-api
分別對應(yīng)ceilometer架構(gòu)中的四個(gè)重要模塊,在ceilometer-agent-compute啟動(dòng)的過程中可能會(huì)出現(xiàn)No module named libvirt的問題,這是因?yàn)楦綦x環(huán)境中沒有安裝python-libvirt的緣故,但是同時(shí)發(fā)現(xiàn)無法使用pip來安裝此庫,但是使用dpkg -l命令查看是發(fā)現(xiàn)python-libvirt的確已經(jīng)安裝,于是直接將全局環(huán)境中的相關(guān)文件拷貝到隔離環(huán)境中來并修改相應(yīng)權(quán)限:
cp /usr/lib/python2.7/dist-packages/libvirt* /opt/stack/grizzlyenv/lib/python2.7/site-packages/
chown stack:stack /opt/stack/grizzlyenv/lib/python2.7/site-packages/libvirt*
這樣應(yīng)該就能夠正常啟動(dòng)了,啟動(dòng)之后可以到mongodb中查看相應(yīng)的數(shù)據(jù)記錄。
3.OpenStack監(jiān)控測量服務(wù)Ceilometer API說明
3.API
3.1 Resources資源
獲取資源的信息。
GET http://HOST:8777/v2/resources
列出所有資源的定義。
GET http://HOST:8777/v2/resources/{resource_id}
獲取指定的資源的詳細(xì)信息。
3.2 Meters計(jì)量
獲取計(jì)量信息。
GET http://HOST:8777/v2/meters
到目前為止的計(jì)量數(shù)據(jù)列表。
GET http://HOST:8777/v2/meters/{meter_id}
獲取指定ID的計(jì)量信息。
POST http://HOST:8777/v2/meters/{meter_id}
更新指定ID的計(jì)量信息列表。
GET http://HOST:8777/v2/meters/{meter_id}/statistics
計(jì)算在指定的時(shí)間范圍內(nèi)的樣本的統(tǒng)計(jì)信息。
3.3 Alarms告警
列表,創(chuàng)建,獲取詳細(xì)信息,更新和刪除報(bào)警。
GET http://HOST:8777/v2/alarms
根據(jù)指定查詢,列出了警報(bào)。
POST http://HOST:8777/v2/alarms
創(chuàng)建一個(gè)報(bào)警。
GET http://HOST:8777/v2/alarms/{alarm_id}
獲取指定ID的報(bào)警信息。
PUT http://HOST:8777/v2/alarms/{alarm_id}
更新指定ID的報(bào)警。
PUT http://HOST:8777/v2/alarms/{alarm_id}/state
設(shè)置一個(gè)指定ID的報(bào)警狀態(tài)。
GET http://HOST:8777/v2/alarms/{alarm_id}/state
獲取指定ID的報(bào)警狀態(tài)。
GET http://HOST:8777/v2/alarms/{alarm_id}/history
組裝指定ID的報(bào)警歷史記錄。
看完了這篇文章,相信你對“OpenStack監(jiān)控測量服務(wù)Ceilometer安裝及API說明的示例分析”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。