...
and the meter code itself can be found here: https://github.com/openstack/collectd-ceilometer-plugin/blob/master/collectd_ceilometer/meters/base.py. Fields in the ceilometer write plugin at the moment are mapped as follows:
ceilometer meter field | collectd field |
---|---|
counter_name | plugin, type |
counter_type | "gauge"-> "gauge", "derive"-> "delta "absolute"-> "cumulative" "counter"-> "cumulative" |
counter_unit | unit |
counter_volume | value |
message_id | - |
project_id | obtained from the auth token |
recorded_at | - |
resource_id | hostname, plugin_instance, type_instance |
resource_metadata | meta |
source | collectd |
timestamp | time |
user_id | obtained from credentials to obtain the auth token |
...
So where there is overlap in meters in terms of the samples collected by collectd and published to ceilometer, we would like to describe the mapping in a generic way.
Proposal 1
collectd json schema
This schema describes the collectd internal types. This schema will be referenced from other mapping schema.
...
language | bash |
---|---|
linenumbers | true |
...
As you can see, the meter sample aren't mapped to look like the meter samples submitted from an OpenStack service where there is overlap.
So where there is overlap in meters in terms of the samples collected by collectd and published to ceilometer, we would like to describe the mapping in a generic way.
Proposal 1
Looking at a combine Schema. This schema describes the collectd internal types, and the ceilometer fields that reference them
Code Block | ||||
---|---|---|---|---|
| ||||
{ "$schema": "http://json-schema.org/draft-04/schema#", "title": "collectd Base Schema", "description": "A schema that defines the collectd meters and events", "definitions": { "value list": { "description": "Statistics in collectd consist of a value list", "type": "object", "properties": { "values" : { "type": "array", "anyOf" : [ { "type" : "object", "properties" : { "absolute" : { "type" : "number" } } }, { "type" : "object", "properties" : { "counter" : { "type" : "number" } } }, { "type" : "object", "properties" : { "derive" : { "type" : "number" } } }, { "type" : "object", "properties" : { "gauge" : { "type" : "number" } } } ] }, "value length" : { "typedescription": "array", "anyOf" : [ The number of values in the data set", { "type" : "object"number" }, "propertiestime" : { "absolutedescription": :"Time {stamp "type"at :which "number"the }value }was }collected", { "type" : "object"number" }, "propertiesInterval" : { "counterdescription": :"interval {at "type"which :to "number"expect }a }new }value", { "type" : "object", "properties" : { "derivenumber" }, "host" : { "typedescription" : "number" } } }, used to identify the host", { "type" : "object"string" }, "propertiesplugin" : { "gaugedescription" : { "type"used :to "number" } } }identify the plugin", ]"type": "string" }, "valueplugin lengthinstance" : { "description": "Theused numberto ofgroup valuesa inset theof datavalues settogether", "type": "numberstring" }, "timetype" : { "description": "Timeunit stampused atto whichmeasure thea value was collected", "type": "numberstring" }, "Intervaltype instance " : { "description": "interval at which to expect a new value "used to distinguish between values that have an identical type", "type": "numberstring" }, "hostmetadata" : { "description": "used to identify the hostan opaque data structure that enables the passing of additional information about a value list", "type": "string" }, } }, "pluginnotifications" : { "description": "usedNotifications in tocollectd identifyare thegeneric pluginmessages", "type": "stringobject", },"properties": { "plugin instanceseverity" : { "description": "usedcan tobe groupone aof setOKAY, ofWARNING, valuesand togetherFAILURE", "type": "string" }, "typetime" : { "description": "unit used to measure a valueTime stamp at which the event was collected", "type": "stringnumber" }, "type instance message" : { "description": "usedThe to distinguish between values that have an identical typenotification message", "type": "string" }, "metadatahost" : { "description": "an opaque data structure that enables the passing of additional information about a value list "description": "used to identify the host", "type": "string" } }, }, "notificationsplugin" : { "description": "Notificationsused into collectdidentify arethe generic messagesplugin", "type": "objectstring", "properties": { }, "severityplugin instance" : { "description": "canused beto onegroup ofa OKAY,set WARNING,of andvalues FAILUREtogether", "type": "string" }, "timetype" : { "description": "Timeunit stampused atto whichmeasure the event was collecteda value", "type": "numberstring" }, "messagetype instance " : { "description": "The notification message "description": "used to distinguish between values that have an identical type", "type": "string" }, "hostmetadata" : { "description": "used to identify the hostan opaque data structure that enables the passing of additional information about a value list", "type": "string" }, } } }, "plugincounter_name": :[ { {"description$ref": "#/definitions/value "used to identify the plugin", "typelist/plugin"}, {"$ref": "string" }, "#/definitions/value list/plugin instance" : {} ], "descriptioncounter_unit": [ "used to group a set of values together"{"$ref": "#/definitions/value list/type_instance"}, {"type$ref": "string" }, "type" #/definitions/value list/type"} ], "counter_volume": { "description$ref": "unit used to measure a value", "type": "string" #/definitions/value list/values" }, "resource_id": [ {"$ref": "#/definitions/value list/host"}, "type instance " : { "description{"$ref": "#/definitions/value list/plugin"}, {"$ref": "used to distinguish between values that have an identical type", "type": "string" }, "metadata" : { "description": "an opaque data structure that enables the passing of additional information about a value list", #/definitions/value list/plugin instance"} ], "timestamp": { "$ref": "#/definitions/value list/time" }, "resource_metadata": { "$ref": "#/definitions/value list/metadata" }, "source": { "type": "string" }, } }"user_id": { "type": "string" } } |
...
collectd to ceilometer mapping example
Issues:
Proposal 1 is too highlevel high level and doesn't get into the internals of what meters get mapped to what and what units should be associated with the meters/events - in essence it doesn't improve on what's there today for overlapping meters. However is good for new meters.
Proposal 2
collectd simple mapping schema (note this is too clunky so it can be ignored):
...