Create Usage Report | ArcGIS REST APIs

Create Usage Report

URL:
https://<root>/usagereports/add
Methods:
POST
Required Capability:
Access allowed only with the default administrator role
Version Introduced:
10.3

Description

The add operation creates a new usage report. A usage report is created by submitting a JSON representation of it to this operation.

Request parameters

ParameterDetails

reportname

The unique name of the report.

Example
Use dark colors for code blocksCopy
1
"reportname": "Server Statistics"

since

The time duration for the report. CUSTOM represents a time range that is specified using the from and to parameters.

Values: LAST_DAY (previous 24 hours) | LAST_WEEK (previous 7 days) | LAST_MONTH (previous 30 days) | CUSTOM

from

(Optional, used if since is set to CUSTOM)

The time stamp (milliseconds since UNIX epoch, namely January 1, 1970, 00:00:00 GMT) for the beginning period of the report.

Example
Use dark colors for code blocksCopy
1
"from": "1568230820504"

to

(Optional, used if since is set to CUSTOM )

The time stamp (milliseconds since UNIX epoch, namely January 1, 1970, 00:00:00 GMT) for the ending period of the report.

Example
Use dark colors for code blocksCopy
1
"to": "1568185200000"

aggregationInterval

(Optional)

The time interval in minutes. Server metrics are summarized and returned for time slices using the specified interval. The time range for the report, specified using the since parameter (and the from and to parameters when since is CUSTOM) is split into multiple slices, each covering a time interval. Server metrics are then summarized for each time slice and returned as data points in the report data. When the aggregationInterval value is not specified, the following defaults are used:

  • LAST_DAY—30 minutes
  • LAST_WEEK—4 hours
  • LAST_MONTH—24 hours
  • CUSTOM—30 minutes up to 1 day, 4 hours up to 1 week, 1 day up to 30 days, and 1 week for longer periods.

queries

A list of queries used to generate the report. Specify the list as an array of JSON objects representing the queries. Each query specifies the list of metrics to be queries for a given set of resourceURIs values. For more information about query properties, see the table below.

Example
Use dark colors for code blocksCopy
1
2
3
4
5
6
"queries": [
  {
    "resourceURIs": ["services/Map_bv_999.MapServer"],
    "metrics": ["RequestCount"]
  }
]

metadata

A JSON object. This is typically used for storing presentation tier data for the usage report, such as report title, colors, line styles, and so on. It's also used to denote visibility in ArcGIS Server Manager for reports created with the Administrator Directory. To make a report created in the Administrator Directory visible to ArcGIS Server Manager, include managerReport as true in the metadata JSON object. When this value is not set (default), reports are not visible in ArcGIS Server Manager. This behavior can be extended to any client that wants to interact with the Administrator Directory. Any user-created value must be processed by the client.

Example
Use dark colors for code blocksCopy
1
"metadata": "This could be any String or JSON Object."

f

The response format. The default value is html.

Values: html | json | pjson

Query parameters

PropertyDescription

resourceURIs

A comma-separated list of resource URIs used to report metrics. This specifies services or folders that are used to gather metrics. The resourceURI is formatted as below:

  • services/—The entire site.
  • services/Folder/—A folder or subfolders in a site. Metrics that are aggregated across all services in that folder and subfolders are reported.
  • services/Folder/ServiceName.ServiceType—A service in a specified folder, for example, services/Map_bv_999.MapServer.
  • services/ServiceName.ServiceType—A service in the root folder, for example: Map_bv_999.MapServer.
Example
Use dark colors for code blocksCopy
1
"resourceURIs": ["services/SampleWorldCities.MapServer","services/System"]

metrics

A comma-separated list of metrics to be reported. The following are supported metrics:

  • RequestCount—The number of requests received
  • RequestsFailed—The number of failed requests
  • RequestsTimedOut—The number of requests that timed out
  • RequestMaxResponseTime—The maximum response time
  • RequestAvgResponseTime—The average response time
  • ServiceRunningInstancesMax—The maximum number of active (running) service instances, sampled at one-minute intervals for a specified service. For ArcGIS Enterprise deployments at 11.0 and below, if you include this metric, it must be the only metric included in the report.
  • RequestAvgWaitTime— The average time that all requests waited for an available ArcSOC instance over a period (total wait time for all requests / number of requests).
  • RequestMaxWaitTime— The maximum time that a service request waited for an available ArcSOC over the specified period.
  • RequestMinWaitTime— The minimum time that a service request waited for an available ArcSOC over the specified period.
Example
Use dark colors for code blocksCopy
1
"metrics": ["RequestCount","RequestsFailed"]

Example usage

Request JSON syntax

Use dark colors for code blocksCopy
1
2
3
4
5
6
7
8
9
10
11
12
13
{
  "reportname": [unique name or id of the report],
  "since": ["LAST_DAY | LAST_WEEK | LAST_MONTH | CUSTOM"],  //Optional, specified when "since" is CUSTOM"
  "from" : [timestamp],  to": [timestamp],  //Optional, specified when "since" is CUSTOM
  "aggregationInterval": [minutes],  //Optional, aggregation interval in minutes
  "queries": [
    {
      "resourceURIs": ["services/Map_bv_999.MapServer"], //Comma separated list of services and/or folders
      "metrics": ["RequestCount"] // Comma-separated list of metrics
    }
  ],
  "metadata": "This could be any String or JSON Object."
}

Single query example

A sample POST request for the add operation that demonstrates a single query:

Use dark colors for code blocksCopy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
POST /webadaptor/admin/usagereports/add HTTP/1.1
Host: machine.domain.com
Content-Type: application/x-www-form-urlencoded
Content-Length: []

usagereport={
  "reportname": 1394219221008,
  "since": "LAST_MONTH",
  "queries": [
    {
      "resourceURIs": [
        "services/Map_bv_999.MapServer"
      ],
      "metrics": [
        "RequestCount"
      ]
    }
  ],
  "metadata": "This could be any String or JSON Object typically used for storing report metadata."
}&f=pjson

Multiple queries example

A sample POST request for the add operation that demonstrates multiple queries:

Use dark colors for code blocksCopy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
POST /webadaptor/admin/usagereports/add HTTP/1.1
Host: machine.domain.com
Content-Type: application/x-www-form-urlencoded
Content-Length: []

usagereport={
  "reportname": "Server Statistics",
  "since": "LAST_WEEK",
  "aggregationInterval": 5,
  "queries": [
    {
      "resourceURIs": [
        "services/SampleWorldCities.MapServer",
        "services/System"
      ],
      "metrics": [
        "RequestCount",
        "RequestsFailed"
      ]
    },
    {
      "resourceURIs": [
        "services/System/CachingTools.GPServer"
      ],
      "metrics": [
        "RequestAvgResponseTime",
        "RequestsTimedOut"
      ]
    }
  ],
  "metadata": "This is a random test String that could contain report metadata in any format."
}&f=json

JSON Response example

Use dark colors for code blocksCopy
1
{"status": "success"}

Your browser is no longer supported. Please upgrade your browser for the best experience. See our browser deprecation post for more details.