OpenStack监控测量服务Ceilometer安装及 API说明

作者:无名    it人知识库   2020-02-13 00:00:00

1.Ceilometer是做什么的

Ceilometer是OpenStack中的一个子项目,它像一个漏斗一样,能把OpenStack内部发生 的几乎所有的事件都收集起来,然后为计费和监控以及其它服务提供数据支撑。Ceilometer的核心架构图
OpenStack监控测量服务Ceilometer安装及 API说明_第1张图片


2.OpenStack监控测量服务Ceilometer安装


2.1 到github下载最新的ceilometer代码

2.2安装mongodb, 由于ceilometer采用mongodb作为默认数据持久化数据库,所以需要先安装mongodb

apt-get install mongodb

2.3在keystone中添加ceilometer用户

需注意:添加的ceilometer账户需要属于admin tenant否则会出现不能获取实例监控信息的情况,并且将此账户添加为ResellerAdmin角色中便于获取swift监控信息。 添加的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

  1. d2to1>=0.2.10,<0.3

  2. pbr>=0.5,<0.6

  3. WebOb>=1.2

  4. kombu

  5. iso8601

  6. argparse

  7. SQLAlchemy>=0.7,<=0.7.99

  8. sqlalchemy-migrate>=0.7.2

  9. pymongo>=2.2

  10. eventlet

  11. anyjson>=0.2.4

  12. Flask==0.9

  13. pecan>=0.2.0

  14. stevedore>=0.7

  15. msgpack-python

  16. python-glanceclient

  17. python-novaclient>=2.6.10

  18. python-keystoneclient>=0.2.3

  19. python-swiftclient

  20. lxml

  21. requests>=1.1

  22. wsme>=0.5b2

  23. pyyaml

  24. oslo.config>=1.1.0

  25. happybase>=0.4

此版本ceilometer使用G版本Openstack中新加的oslo.config模块完成配置文件读取模块。

此外要求WebOb的版本要在1.2以上,查看F版本Openstack使用的此库版本为1.0.8,这是比较大的冲突,并且发现有很多人反映此库与之前的库不兼容的情况(https://bugs.launchpad.net/ceilometer/+bug/1092227),在我实际的安装过程中也发现此库不能被python-novaclient, python-glanceclient等库所使用。于是我使用virtualenv(https://pypi.python.org/pypi/virtualenv)建立了一个隔离的python环境来安装运行ceilometer及相关依赖。




2)安装virtualenv并建立隔离沙箱

sudo pip install virtualenv #安装

virtualenv grizzlyenv #建立名为grizzlyenv的隔离环境

source grizzlyenv/bin/activate #进入grizzlyenv隔离环境

进入后在提示符前会出现提示,如  

(grizzlyenv)root@ceilotest:/opt#

在此环境下,有一套独立于全局python的环境,在此使用pip和easy_install安装python包都可以不影响全局的python环境,使用完毕之后使用deactivate命令即可退出到全局环境,相关的使用方法在网上都可以找到,在此不赘述




3)隔离环境安装完毕之后,就能够在这之中安装ceilometer了

#cd ceilometer

#python setup.py develop

安装完之后可以看到所依赖的包都安装在了grizzlyenv/lib/python2.7/site-packages/ 路径之下。

将ceilometer/etc/ceilometer/下所有文件拷贝到/etc/ceilometer/目录下(没有则新建),并将其中ceilometer.conf.sample文件修改为:

ceilometer.conf

  1. [DEFAULT]

  2. verbose=True

  3. debug=True

  4. os_auth_url = http://192.168.5.202:35357/v2.0

  5. os_tenant_name = admin

  6. os_password = admin

  7. os_username = ceilometer

  8. policy_file = /etc/ceilometer/policy.json

  9. notification_topics = notifications,glance_notifications

  10. rabbit_password = admin

  11. rabbit_host = 127.0.0.1

  12. rabbit_max_retries = 10

  13. rpc_backend = ceilometer.openstack.common.rpc.impl_kombu


  14. [keystone_authtoken]

  15. signing_dir = /etc/ceilometer

  16. admin_tenant_name = admin

  17. admin_password = admin

  18. admin_user = ceilometer

  19. auth_protocol = http

4) 启动ceilometer

在screen中开启四个选项卡,依次运行:

ceilometer-collector

ceilometer-agent-central

ceilometer-agent-compute

ceilometer-api

分别对应ceilometer架构中的四个重要模块,在ceilometer-agent-compute启动的过程中可能会出现No module named libvirt的问题,这是因为隔离环境中没有安装python-libvirt的缘故,但是同时发现无法使用pip来安装此库,但是使用dpkg -l命令查看是发现python-libvirt的确已经安装,于是直接将全局环境中的相关文件拷贝到隔离环境中来并修改相应权限:

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*

这样应该就能够正常启动了,启动之后可以到mongodb中查看相应的数据记录。



3.OpenStack监控测量服务Ceilometer  API说明


3.API


3.1 Resources资源


获取资源的信息。

  

GET           http://HOST:8777/v2/resources

列出所有资源的定义。

GET           http://HOST:8777/v2/resources/{resource_id}

获取指定的资源的详细信息。

3.2 Meters计量


获取计量信息。

  

GET           http://HOST:8777/v2/meters

到目前为止的计量数据列表。

  

GET           http://HOST:8777/v2/meters/{meter_id}

获取指定ID的计量信息。

  

POST         http://HOST:8777/v2/meters/{meter_id}

更新指定ID的计量信息列表。

  

GET           http://HOST:8777/v2/meters/{meter_id}/statistics

计算在指定的时间范围内的样本的统计信息。

3.3 Alarms告警


列表,创建,获取详细信息,更新和删除报警。

  

GET           http://HOST:8777/v2/alarms

根据指定查询,列出了警报。

  

POST         http://HOST:8777/v2/alarms

创建一个报警。

  

GET           http://HOST:8777/v2/alarms/{alarm_id}

获取指定ID的报警信息。

  

PUT           http://HOST:8777/v2/alarms/{alarm_id}

更新指定ID的报警。

  

PUT           http://HOST:8777/v2/alarms/{alarm_id}/state

设置一个指定ID的报警状态。

  

GET           http://HOST:8777/v2/alarms/{alarm_id}/state

获取指定ID的报警状态。

  

GET           http://HOST:8777/v2/alarms/{alarm_id}/history

组装指定ID的报警历史记录。


it人知识库 该篇文章地址:https://m.itpeo.net/15310/3708367.html

Tag:监控测量丈量服务安装说明



我要分享:

  • 微信
  • QQ好友
  • QQ空间
  • 新浪微博


热门推荐

UIApplicationMain方法介绍

UIApplicationMain方法介绍

在IOS程序的main函数中执行了一个UIApplicationMain这个函数,下面介绍以下这个函数的作用。 &... ...

Info.plist和pch文件的作用

Info.plist和pch文件的作用

在IOS开发中有两个常见文件“工程名-Info.plist”和“工程名-Prefix.pch”文件,下面介绍一下这两个文... ...

IOS开发计算文本尺寸

IOS开发计算文本尺寸

在IOS开发中例如微博,QQ聊天界面中要显示大量的文字信息,这样需要计算出文字部分的尺寸,才能设计出合适的控件尺寸和位置... ...

『摄影师访谈』Walker Evans,摄影是对事物本身的超越

『摄影师访谈』Walker Evans,摄影是对事物本身的超越

Walker Evans(1903-1975)为美国农场安全管理局(Farm Security Administ... ...

NodeJs 多核多进程并行框架实作

NodeJs 多核多进程并行框架实作

多核编程的重要性无需多说, 我们直奔主题,目前nodejs 的网络服务器有以下几种支持多进程的方式: #1 开... ...

"[如意猎奇]社会各行业内幕 各位看客斟酌看待

3楼 我是相机促销员 其实像一般大点的卖场 很热心的跟你去介绍的人 肯定不是为了帮你介绍一款好点的东西。... ...

DotNet持续集成环境构建及配置之安装篇

DotNet持续集成环境构建及配置之安装篇

DotNet持续集成环境构建及配置之安装篇 准备工作: 安装Windows Server 2003及最新补丁... ...

我们用一个实例CISample来说明怎么配置CC.Net、VSS等。

我们用一个实例CISample来说明怎么配置CC.Net、VSS等。

我们用一个实例CISample来说明如何配置CC.Net、VSS等。 持续集成服务器源代码管理器配置: 从程序里... ...

java 框架

java 框架

  A 代码生成器(开发利器);  B 阿里数据库连接池drui... ...

MINA学习笔记四——第三章Session

MINA学习笔记四——第三章Session

第四章 会话 会话是MINA的核心:每次一个客户端连接到服务器,一个新的会话将被创建,而且该会话在客户端连... ...

MINA学习笔记三——第三章 IoService

MINA学习笔记三——第三章 IoService

第三章 IoService        一个... ...

sql 语句使用

sql 语句使用

1. 有一张表t_stu;其中三个字段:name,gender,grade;要求用一条sql语句查出男生前5名和女生前五... ...

oracle安装及体系结构

oracle安装及体系结构

1. 安装 数据库名:sid (系统标识符) + 后缀 10G过后,安装过程中要求修改SYS(默认manag... ...

Struts2系列之一:构建struts2项目

Struts2系列之一:构建struts2项目

Struts2系列之二:页面传值 Struts2系列之三:注解式Action 1. 新建一个Mave... ...

Page_Load()

Page_Load()

Page_Load,即页面载入要执行的事件; Page_Load的执行分为两种情况; 1.Page_Load事件的... ...

值类型与引用类型(Stuct---Class)

值类型与引用类型(Stuct---Class)

值类型有:Int Double Float Decimal Boolean Byte Char Single Enum ... ...

使用存储过程操作数据库(实现增删改查)

使用存储过程操作数据库(实现增删改查)

使用存储过程操作数据库    添加数据: --创建一个存储过程,向表中插入一条数据 crea... ...

使用二进制协议 (附源码)

使用二进制协议 (附源码)

使用二进制协议 (附源码) 在网络上,交互的双方基于TCP或UDP进行通信,通信协议的格式通常分为两类:文本消息... ...

soap消息拦截器SOAPHandler【handler-chain.xml】

soap消息拦截器SOAPHandler【handler-chain.xml】

SOAP handler is a SOAP message interceptor, which is able... ...

快码表类库DataDictionary

快码表类库DataDictionary

 代码没什么难度,主要是学习这种基础数据使用思想。   import java.uti... ...

最新IT资讯

必填

◎已有 0 人评论


电脑版

版权所有:IT人知识库 m.itpeo.net

返回顶部

本网站部分内容来自互联网,版权归原作者所有,文章内容仅代表原作者个人观点,如有侵权请联系我们删除