| .. |
| .. |
| .. Licensed under the Apache License, Version 2.0 (the "License"); |
| .. you may not use this file except in compliance with the License. |
| .. You may obtain a copy of the License at |
| .. |
| .. http://www.apache.org/licenses/LICENSE-2.0 |
| .. |
| .. Unless required by applicable law or agreed to in writing, software |
| .. distributed under the License is distributed on an "AS IS" BASIS, |
| .. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| .. See the License for the specific language governing permissions and |
| .. limitations under the License. |
| .. |
| |
| .. _to-api-deliveryservice_stats: |
| |
| ************************* |
| ``deliveryservice_stats`` |
| ************************* |
| |
| ``GET`` |
| ======= |
| Retrieves time-aggregated statistics on a specific :term:`Delivery Service`. |
| |
| :Auth. Required: Yes |
| :Roles Required: None\ [#tenancy]_ |
| :Permissions Required: STAT:READ, DELIVERY-SERVICE:READ |
| :Response Type: Object |
| |
| Request Structure |
| ----------------- |
| .. table:: Request Query Parameters |
| |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | Name | Required | Description | |
| +=====================+===================+===========================================================================================================================================================================================+ |
| | deliveryService | yes\ [#ds-param]_ | Either the :ref:`ds-xmlid` of a :term:`Delivery Service` for which statistics will be aggregated or the integral, unique identifier of said :term:`Delivery Service` | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | deliveryServiceName | yes\ [#ds-param]_ | The :ref:`ds-xmlid` of the :term:`Delivery Service` for which statistics will be aggregated | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | endDate | yes | The date and time until which statistics shall be aggregated in :rfc:`3339` format (with or without sub-second precision), the number of nanoseconds since the Unix | |
| | | | Epoch, or in the same, proprietary format as the ``lastUpdated`` fields prevalent throughout the Traffic Ops API | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | exclude | no | Either "series" to omit the data series from the result, or "summary" to omit the summary data from the result - directly corresponds to fields in the | |
| | | | `Response Structure`_ | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | interval | no | Specifies the interval within which data will be "bucketed"; e.g. when requesting data from 2019-07-25T00:00:00Z to 2019-07-25T23:59:59Z with an interval of "1m", | |
| | | | the resulting data series (assuming it is not excluded) should contain | |
| | | | :math:`24\frac{\mathrm{hours}}{\mathrm{day}}\times60\frac{\mathrm{minutes}}{\mathrm{hour}}\times1\mathrm{day}\times1\frac{\mathrm{minute}}{\mathrm{data point}}=1440\mathrm{data\;points}`| |
| | | | The allowed values for this parameter are valid InfluxQL duration literal strings matching :regexp:`^\d+[mhdw]$` | |
| | | | | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | limit | no | A natural number indicating the maximum amount of data points should be returned in the ``series`` object | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | metricType | yes | The metric type being reported - one of: | |
| | | | | |
| | | | kbps | |
| | | | The total traffic rate in kilobytes per second served by the :term:`Delivery Service` | |
| | | | tps_total | |
| | | | The total traffic rate in transactions per second served by the :term:`Delivery Service` | |
| | | | tps_2xx | |
| | | | The total traffic rate in transactions per second serviced with 200-299 HTTP status codes | |
| | | | tps_3xx | |
| | | | The total traffic rate in transactions per second serviced with 300-399 HTTP status codes | |
| | | | tps_4xx | |
| | | | The total traffic rate in transactions per second serviced with 400-499 HTTP status codes | |
| | | | tps_5xx | |
| | | | The total traffic rate in transactions per second serviced with 500-599 HTTP status codes | |
| | | | | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | offset | no | A natural number of data points to drop from the beginning of the returned data set | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | orderby | no | Though one struggles to imagine why, this can be used to specify "time" to sort data points by their "time" (which is the default behavior) | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| | startDate | yes | The date and time from which statistics shall be aggregated in :rfc:`3339` format (with or without sub-second precision), the number of nanoseconds since the Unix | |
| | | | Epoch, or in the same, proprietary format as the ``lastUpdated`` fields prevalent throughout the Traffic Ops API | |
| +---------------------+-------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ |
| |
| .. _deliveryservice_stats-get-request-example: |
| .. code-block:: http |
| :caption: Request Example |
| |
| GET /api/4.0/deliveryservice_stats?deliveryServiceName=demo1&startDate=2019-07-22T17:55:00Z&endDate=2019-07-22T17:56:00.000Z&metricType=tps_total HTTP/1.1 |
| User-Agent: python-requests/2.20.1 |
| Accept-Encoding: gzip, deflate |
| Accept: application/json;timestamp=unix, application/json;timestamp=rfc;q=0.9, application/json;q=0.8, */*;q=0.7 |
| Connection: keep-alive |
| Cookie: mojolicious=... |
| |
| Content Format |
| """""""""""""" |
| It's important to note in :ref:`deliveryservice_stats-get-request-example` the use of a complex "Accept" header. This endpoint accepts two special media types in the "Accept" header that instruct it on how to format the timestamps associated with the returned data. Specifically, Traffic Ops will recognize the special, optional, non-standard parameter of :mimetype:`application/json`: ``timestamp``. The values of this parameter are restricted to one of |
| |
| rfc |
| Returned timestamps will be formatted according to :rfc:`3339` (no sub-second precision). |
| unix |
| Returned timestamps will be formatted as the number of nanoseconds since the Unix Epoch (midnight on January 1\ :sup:`st` 1970 UTC). |
| |
| .. impl-detail:: The endpoint passes back nanoseconds, specifically, because that is the form used both by InfluxDB, which is used to store the data being served, and Go's standard library. Clients may need to convert the value to match their own standard libraries - e.g. the :js:class:`Date` class in Javascript expects milliseconds. |
| |
| The default behavior - when only e.g. :mimetype:`application/json` or :mimetype:`*/*` is given - is to use :rfc:`3339` formatting. It will, however, respect quality parameters. It is suggested that clients request timestamps they can handle specifically, rather than relying on this default behavior, as it **is subject to change** and is in fact **expected to invert in the next major release** as string-based time formats become deprecated. |
| |
| .. seealso:: For more information on the "Accept" HTTP header, consult `its dedicated page on MDN <https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept>`_. |
| |
| Response Structure |
| ------------------ |
| :series: An object containing the actual data series and information necessary for working with it. |
| |
| :columns: This is an array of names of the columns of the data contained in the "values" array - should always be ``["time", "sum_count"]`` |
| :count: The number of data points contained in the "values" array |
| :name: The name of the data set. Should always match :samp:`{metric}.ds.1min` where ``metric`` is the requested ``metricType`` |
| :values: The actual array of data points. Each represents a length of time specified by the ``interval`` query parameter |
| |
| :time: The time at which the measurement was taken. This corresponds to the *beginning* of the interval. This time comes in the format of either an :rfc:`3339`-formatted string, or a number containing the number of nanoseconds since the Unix Epoch depending on the "Accept" header sent by the client, according to the rules outlined in `Content Format`_. |
| :value: The value of the requested ``metricType`` at the time given by ``time``. This will always be a floating point number, unless no data is available for the data interval, in which case it will be ``null`` |
| |
| :source: A legacy field meant only for plugins that override this endpoint to name themselves. Should always be "TrafficStats". |
| |
| .. deprecated:: 1.4 |
| As this has no known purpose, developers are advised it will be removed in the future. |
| |
| :summary: An object containing summary statistics describing the data series |
| |
| :average: The arithmetic mean of the data's values |
| :count: The number of measurements taken within the requested timespan. This is, in general, **not** the same as the ``count`` field of the ``series`` object, as it reflects the number of underlying, un-"bucketed" data points, and is therefore dependent on the implementation of Traffic Stats. |
| :fifthPercentile: Data points with values less than or equal to this number constitute the "bottom" 5% of the data set |
| :max: The maximum value that can be found in the requested data set |
| :min: The minimum value that can be found in the requested data set |
| :ninetyEighthPercentile: Data points with values greater than or equal to this number constitute the "top" 2% of the data set |
| :ninetyFifthPercentile: Data points with values greater than or equal to this number constitute the "top" 5% of the data set |
| :totalBytes: When the ``metricType`` requested is ``kbps``, this will contain the total number of bytes transferred by the :term:`Delivery Service` within the requested time window. Note that fractional amounts are possible, as the data transfer rate will almost certainly not be cleanly divided by the requested time range. |
| :totalTransactions: When the ``metricType`` requested is **not** ``kbps``, this will contain the total number of transactions completed by the :term:`Delivery Service` within the requested time window. Note that fractional amounts are possible, as the transaction rate will almost certainly not be cleanly divided by the requested time range. |
| |
| :version: A legacy field that seems to have been meant to indicate the API version used. Will always be "1.2" |
| |
| .. deprecated:: 1.4 |
| As this has no known purpose, developers are advised it will be removed in the future. |
| |
| .. code-block:: http |
| :caption: Response Example |
| |
| HTTP/1.1 200 OK |
| Access-Control-Allow-Credentials: true |
| Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Set-Cookie, Cookie |
| Access-Control-Allow-Methods: POST,GET,OPTIONS,PUT,DELETE |
| Access-Control-Allow-Origin: * |
| Content-Encoding: gzip |
| Content-Type: application/json |
| Set-Cookie: mojolicious=...; Path=/; Expires=Mon, 18 Nov 2019 17:40:54 GMT; Max-Age=3600; HttpOnly |
| Whole-Content-Sha512: zXJGjcYuu6HxWINVp8HA1gL31J3ukry5wCsTDNxtP/waC6rSD8h10KJ9jEAtRzJ9owOSVPvKaA/2bRu/QeuCpQ== |
| X-Server-Name: traffic_ops_golang/ |
| Date: Mon, 22 Jul 2019 17:57:14 GMT |
| Transfer-Encoding: chunked |
| |
| { "response": { |
| "series": { |
| "columns": [ |
| "time", |
| "sum_count" |
| ], |
| "count": 2, |
| "name": "tps_total.ds.1min", |
| "tags": { |
| "cachegroup": "total" |
| }, |
| "values": [ |
| [ |
| 1563818100000000000, |
| 0 |
| ], |
| [ |
| 1563818160000000000, |
| 0 |
| ] |
| ] |
| }, |
| "source": "TrafficStats", |
| "summary": { |
| "average": 0, |
| "count": 2, |
| "fifthPercentile": 0, |
| "max": 0, |
| "min": 0, |
| "ninetyEighthPercentile": 0, |
| "ninetyFifthPercentile": 0, |
| "totalBytes": null, |
| "totalTransactions": 0 |
| }, |
| "version": "1.2" |
| }} |
| |
| .. [#tenancy] This endpoint respects :term:`Tenancy`, and users whose :term:`Tenant` does not have access to a :term:`Delivery Service` will be unable to view the statistics of said :term:`Delivery Service`. |
| .. [#ds-param] Either ``deliveryServiceName`` or ``deliveryService`` *must* be present, but if both are ``deliveryServiceName`` will be used and ``deliveryService`` will be ignored. |