Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Code Block
languagebash
linenumberstrue
{
    "$schema": "http://json-schema.org/draft-04/schema#",
    "title": "collectd Base Schema",
    "description": "A schema that defines the collectd meters and events",
    "definitions": {
		        "collectd_field": {
			            "description": "collectd_fields",
			
            "type": "object",
			            "properties": {
				
                "anyOf" : {
					
                    "Interval" : {
						                        "description": "interval at which to expect a new value",
						
                        "type": "number"
					},
					                    },
                    "host" : {
						
                        "description": "used to identify the host",
						"type": "string"
					},
					"message" : {
						"description": "The notification message",
						                        "type": "string"
					},
					"metadata" : {
						"description": "an opaque data structure that enables the passing of additional information about a value list",
						"type": "string"
					},
					"plugin" : {
						"description": "used to identify the plugin",
						"type": "string"
					},
					"plugin instance" : {
						"description": "used to group a set of values together",
						"type": "string"
					},
					"severity" : {
						"description": "can be one of OKAY, WARNING, and FAILURE",
						                    },
                    "message" : {
                        "description": "The notification message",
                        "type": "string"
					},
					"time" : {
						"description": "Time stamp at which the value was collected",
						"type": "number"
					},
					"type
                    },
                    "metadata" : {
						"description": "unit used to measure a value",
						"type": "string"
					},
					"type instance " : {
						                        "description": "used to distinguish between values that have an identical type",
						"type": "string"
					},
					"values" : {
						"type": "object",
						"anyOf" : {
							 "absolute" : { "type" : "number" } ,
							 "counter" : { "type" : "number" },
							 "derive" : { "type" : "number" },
							 "gauge" : { "type" : "number" }
						}
					},
					"value length" : {
						"description": "The number of values in the data set",
						"type": "number"
					}
				}
			}
		},
		"mappings": {
			"description": "mapping pair",
			"type": "object",
			"properties": {
			    "oneOf": {
				"$ref": "#/definitions/collectd_field",
				"collectd_string": {an opaque data structure that enables the passing of additional information about a value list",
                        "type": "string"
                    },
                    "plugin" : {
                        "description": "used to identify the plugin",
                        "type": "string"
}
				},
				"new_string": { "type": "string" }
			}
		},
		"timestamps": {                    },
              "description": "Mappings from collectd timestamps to other framework timestamps",
 "plugin instance" : {
          "type": "object",             "propertiesdescription": {
				"mappings": {
					"description": "array of mappings from collectd to other frameworks",
					"used to group a set of values together",
                        "type": "array",
					"items": {  
						"$ref": "#/definitions/mapping",
						"conversion": "string"
					}
				}
			},
			"required": [ "mappings" ]
  string"
                    },
     }, 		"units": {             "descriptionseverity" : {
"Mappings from collectd units to other framework units",                  "typedescription": "objectcan be one of OKAY, WARNING, and FAILURE",
            "properties": { 				"mappings": { 					"description": "array of mappings from collectd to other frameworks", 					"type": "arraystring",
					"items": {  
						"$ref": "#/definitions/mapping",
						"unit_conversion": "string"
					}
				}
			},
			"required": [ "mappings" ]
                    },
            }	 	}, 	"field_mappings": {
		"description": "array of field_mappings",
		"type": "array",
		"items": {
				"$ref": "#/definitions/mappings",
				"$ref1": "#/definitions/timestamps",
				"$ref2": "#/definitions/units"
		}
	}
}

 

Taking the following ceilometer meter as an example:

Code Block
  - name: 'vcpus'     "time" : {
                        "description": "Time stamp at which the value was collected",
                 event_type: 'compute.instance.*'      "type": 'gauge'"number"
     unit: 'vcpu'      volume: $.payload.vcpus        },
                    "type" : {
       user_id: $.payload.user_id      project_id: $.payload.tenant_id      resource_id: $.payload.instance_id

...

  "description": "unit used to measure a value",
                        "type": "string"
                    },
                    "type instance " : {
                        "description": "used to distinguish between values that have an identical type",
                        "type": "string"
                    },
                    "values" : {
                        "type": "object",
                        "anyOf" : {
                            "absolute" : { "type" : "string" } ,
                            "counter" : { "type" : "string" },
                            "derive" : { "type" : "string" },
                            "gauge" : { "type" : "string" },
							"actual_values" : { "type" : "string" }
                        }
                    },
                    "value length" : {
                        "description": "The number of values in the data set",
                        "type": "number"
                    }
                }
            }
        },
        "mappings": {
            "description": "mapping pair",
            "type": "object",
            "properties": {
                "oneOf": {
                "$ref": "#/definitions/collectd_field",
                "collectd_string": { "type": "string" }
                },
                "new_string": { "type": "string" },
				"new_value": { "type": "string" }
            }
        },
        "mappings_with_conversion": {
            "description": "Mappings from collectd timestamps to other framework timestamps",
            "type": "object",
            "properties": {
                "transform": {
                    "description": "array of mappings from collectd to other frameworks",
                    "type": "array",
                    "items": {  
                        "$ref": "#/definitions/mapping",
                        "conversion": "string"
                    }
                }
            },
            "required": [ "mappings" ]
        }
    },
    "field_mappings": {
        "description": "array of field_mappings",
        "type": "array",
        "items": {
		    "set": {
			    "description": "set of associated of field_mappings",
				"type": "array",
				"anyOf":{
					"$ref": "#/definitions/mappings",
					"$ref1": "#/definitions/mappings_with_conversion"
				}
			}
        }
    }
}

 

Taking the following ceilometer meter as an example:

Code Block
  - name: 'compute.node.cpu.percent'

    event_type: 'compute.metrics.update'

    type: 'gauge'

    unit: 'percent'

    volume: $.payload.metrics[?(@.name='cpu.percent')].value * 100

    resource_id: $.payload.host + "_" + $.payload.nodename

    timestamp: $.payload.metrics[?(@.name='cpu.percent')].timestamp

    metadata:

      event_type: $.event_type

      host: $.publisher_id

      source: $.payload.metrics[?(@.name='cpu.percent')].source

 

Using the schema above:

Code Block
languagebash
{
    "field_mappings": [
	    "set": [
		    {
			    "new_string": "counter_name",
				"collectd_field": {
					"plugin": "cpu"
				},
				"conversion": "cpu"
			},
			{
				"new_string": "counter_type",
				"collectd_field": {
					"values": {
						"gauge": "cumulative"
					}
				}
			},
			{
				"new_string": "counter_volume",
				"collectd_field": {
					"values": {
						"actual_values": "values_array"
					}
				}
				"conversion": "None"
			},
			{
				"new_string": "timestamp",
				"collectd_string": "timestamp"
			},
			{
				"new_string": "source",
				"new_value": "collectd"
			},
			{
				"new_string": "resource_id",
				"collectd_field": {
					"values": {
						"host": "uuid",
						"plugin instance": "plugin_instance"
					}
				}
			}
		]
	]
}

 

Key_words: values_array.

 

References

http://docs.openstack.org/admin-guide/telemetry-data-collection.html

...