Openstack ceilometer主要用于监控虚拟机、服务(glance、image、network等)和事件。虚拟机的监控项主要包括CPU、磁盘、网络、instance。本文在现有监控项的基础上,介绍如何增长新的监控项目。 python
1、Ceilometer框架结构 git
Ceilometer监控经过在计算节点部署Compute服务,轮询其计算节点上的instance,获取各自的CPU、网络、磁盘等监控信息,发送到RabbitMQ,Collector服务负责接收信息进行持久化存储,详细框架以下图所示(点击查看大图)。 github
本文主要介绍instance的监控,获取instance的监控数据发送到message队列。instance的监控数据的获取主要经过Compute服务以pollster方式轮询各虚拟机,Compute服务类图以下(点击查看大图)。 mongodb
经过该类图可知,新增项目须要继承ComputePollster类,并实现get_samples方法。最后经过配置便可,获取到新的监控项数据。因为,现有的Ceilometer没有对内存的实时监控,本文之内存为例,详细介绍增长新的监控项的流程。 数据库
2、新增虚拟机监控项 windows
现有虚拟机的监控项目,没有对内存的监控。本文之内存为例,介绍增长内存监控模块的方法,增长内存监控方法比较简单,主要在compute端增长获取数据的方式,而后修改配置文件,便可将数据持久化数据库中。详细步骤以下: 网络
一、在 ceilometer/ceilometer/compute/pollsters目录下新建文件mem.py(名字自定义)。在该文件下定义MEMPollster类并实现get_samples方法: 数据结构
class MEMPollster(plugin.ComputePollster): |
def get_samples(self, manager, cache, instance): |
二、get_samples中获取内存数据的方式,可参考CPU获取数据的架构,在ceilometer/ceilometer/compute/virt/inspector.py 中定义返回数据的格式: 架构
MEMStats = collections.namedtuple('MEMStats', ['total', 'free']) |
获取内存方式多样,本文采用读取proc文件获取instance所在进程占用的内存大小,有时获取的数据比instance最大内存大,因此该方式对windows系统的虚机有必定的偏差,仅做为示例参考。方法定义以下: 框架
def inspect_mems(self, instance_name): |
获取数据后,按sample数据结构返回便可。
三、设计完上述获取数据的方式后,并不能轮询到内存数据,还须要修改一些设置文件。
首先,修改ceilometer/setup.cfg文件,在该文件ceilometer.poll.compute下,增长
mem = ceilometer.compute.pollsters.mem:MEMPollster |
其次,因为包冲突的问题,将ceilometer安装在隔离环境中,因此source隔离环境,从新安装ceilometer,以上配置才能生效。执行 python setup.py develop 命令便可。
四、重启ceilometer服务,进入mongodb的ceilometer数据库便可在meter表中查看mem的监控数据。
监控的一些实现,能够作一下:https://github.com/kevinjs/procagent