Skip to content

Latest commit

 

History

History
133 lines (110 loc) · 5.43 KB

README.md

File metadata and controls

133 lines (110 loc) · 5.43 KB

Zenoss Central Query Service

This project provides a HTTP/JSON based metric service capability for the information that Zenoss stores in its central repository.

The resources this service provides are:

  • GET /chart - return a list of chart resources.

This operation can take a start and end query parameter that specifies the range (inclusive) that the requester wishes to get back. This enables paging through the list of available charts. Additionally a count=true query parameter can be specified such that the total count of charts will be returned as well. This operation will return a JSON structure of the form:

    {
        "start" : #,
        "end"   : #,
        "count" : #,
        "ids"   : [ "<id>", "<id>", ...]
    }
  • GET /chart/{id}

  • POST /chart

  • PUT /chart/{id}

  • DELETE /chart/{id} All operations on the chart resource assume a chart JSON structure as payload. The structure is

    {
        "name" : "<chart-name>",
        "range" : { [optional]
            "start" : <datetime>,
            "end"   : <datetime>,
        },
        "filter" : { [optional]
            "name" : "value", ...
        },
        "datapoints" : [
            {
                "type" : i.e. line, bar, etc
                "consolidator" : avg, sum, etc
                "metric" : metric name
            }, ...
        ]
    }
    
  • POST /query/performance - return the performance metrics that match the search criteria. The results are the same as for the get request below, the difference is that instead of specifying the criteria as query parameters the criteria is specified as an JSON object in the POST data. The JSON structure that is supported on this POST call follows the following format:

    {
        "start"   : "<datetime>",
        "end"     : "<datetime>",
        "exact"   : true or false,
        "series"  : true or false,
        "metrics" : [
            {
                "metric" : "<metric name>",
                "aggregator" : "<aggregator>",
                "downsample" : "<downsample>",
                "rate"       : true or false,
                "tags"       : {
                    "tag-name" : "tag-value", ...
                } 
            }, ...
        ]
    }
    
  • GET /query/performance - returns the performance metrics that match the search criteria.

    This resource is loosely based on the OpenTSDB HTTP query API at OpenTsdb and supports the following query parameters:

    • id = <_string_><br/> This ID is specified by the client and is not checked for uniqueness by the server, nor even used by the server.

    • start=<_date_ | _relative-date_ | _now_><br/> A date should be specified in the format "yyyy/MM/dd-HH:mm:ss-ZZZ"
      A relative date is of the format [-]#[ywdhms]-ago
      "now" translates to the current time when the request is made

    • end=<_date_ | _relative-date_ | _now_><br/> A date should be specified in the format "yyyy/MM/dd-HH:mm:ss-ZZZ"
      A relative date is of the format [-]#[ywdhms]-ago
      "now" translates to the current time when the request is made

    • exact=<_true_ | _false_>

    • series-<_true_ | _false_><br/> Determines is the results are grouped as individual series based on the results based on metric name and tag values not based on the number of queries specified.

    • query=<_AGG:[rate:][downsample:]metric[{tags}]_>

      AGG = min | max | sum | avg

      downsample = _like_ 10m-avg

      tags = name=tag-value

      tag-value = \* __or__ partial\* __or__ tag-value | tag-value

      Multiple "query" parameters can be specified in which case all query results will be generated from a single HTTP/JSON connection.

The results of the query will be a JSON object of the form:

    {
        "clientId" : "2342feo234",
        "source": "OpenTSDB",
        "startTime" : "5s-ago",
        "startTimeActual": "2013/06/19-17:00:00-+0000",
        "endTime" : "now",
        "endTimeActual": "2013/06/19-19:05:00-+0000",
        "exactTimeWindow": true,
        "series": false,
        "results" : [ 
            {
                "metric" : "laLoadInt1",
                "timestamp" : 1371512029,
                "value" : 49,
                "tags" : {
                    "tag1" : "value1",
                    "tag2" : "value2",
                    "tag3" : "value3"
                }
            },
            {
                "metric" : "laLoadInt1",
                "timestamp" : 1371512044,
                "value" : 52,
                "tags" : {
                    "tag1" : "value1",
                    "tag2" : "value2",
                    "tag3" : "value3"
                }
            }
        ]
    }

This response object contains the information which was given as part of the query as well as an array of results for each query. While some of the information in this response object may seem redundant it is not as each data point in the underling storage (OpenTSDB) may have a different set of tags.

Also note the client id attribute in the response object. This is the value that was specified as the id as the query parameter.