Historical Stats

Data latency

Data with day resolution is bucketed based on UTC days and each day's data becomes available around 2am the following day. hour resolution buckets become available approximately 15 minutes after the end of each hour. minute data usually becomes available two minutes after the end of the minute, but can take up to 15 minutes. If your use case requires data closer to real-time, consider using the real-time API instead.

We do not report data for time periods that have not yet ended.

IMPORTANT: You cannot retrieve data at minute resolution that is older than 35 days. Contact support@fastly.com if you require data at minute resolution older than this.

Query options (Time range, Sampling rate, and Regions)

When the from or to parameters specify a date without a time, the time component will be set to 00:00. To specify a different time, use a Unix timestamp or an expression such as from=2013-01-01%2008:00&to=2013-01-02%2008:00

If from is omitted, the time range will start at a point determined by the value of by:

  • /stats or /stats?by=day: one month ago
  • /stats?by=hour: one day ago
  • /stats?by=minute: 30 minutes ago

If you define values for all of the from, to, and by parameters you can accidentally ask for a very large data set. We will not process exceedingly large queries.

IMPORTANT: All absolute time references in the historical stats API are expressed in UTC.

Examples

Returns stats grouped by day, for the last ten days, across all regions:

/stats?from=10+days+ago

Stats from Tuesday 14th May 2017 @ 20:29:37 UTC to Thursday 16th May 2017 @ 20:29:37 UTC:

/stats?from=1494793777&to=1494966577

Daily stats from January 1st, 2017 (2017-01-01) to February 1st, 2017 (2017-02-01):

/stats?from=1%2F1%2F2017&to=2%2F1%2F2017

Returns stats for US POPs only:

/stats?region=usa

Returns stats for European POPs only:

/stats?region=europe

The Historical Stats API allows you to programmatically retrieve historical caching statistics derived from your Fastly services. You can use these metrics to help you optimize your site’s data caching and analyze your site’s traffic.

Data model

metaobjectMeta information about the scope of the query in a human readable format.
msgstringIf the query was not successful, this will provide a string that explains why.
statusstringWhether or not we were able to successfully execute the query.
dataarray

Results data model

The results of the query, grouped by service (and optionally, region), and aggregated over the appropriate time span.

attack_blocked_req_body_bytesintegerTotal body bytes received from requests that triggered a WAF rule that was blocked.
attack_blocked_req_header_bytesintegerTotal header bytes received from requests that triggered a WAF rule that was blocked.
attack_logged_req_body_bytesintegerTotal body bytes received from requests that triggered a WAF rule that was logged.
attack_logged_req_header_bytesintegerTotal header bytes received from requests that triggered a WAF rule that was logged.
attack_passed_req_body_bytesintegerTotal body bytes received from requests that triggered a WAF rule that was passed.
attack_passed_req_header_bytesintegerTotal header bytes received from requests that triggered a WAF rule that was passed.
attack_req_body_bytesintegerTotal body bytes received from requests that triggered a WAF rule.
attack_req_header_bytesintegerTotal header bytes received from requests that triggered a WAF rule.
attack_resp_synth_bytesintegerTotal bytes delivered for requests that triggered a WAF rule and returned a synthetic response.
bandwidthintegerTotal bytes delivered (resp_header_bytes + resp_body_bytes + bereq_header_bytes + bereq_body_bytes + compute_resp_header_bytes + compute_resp_body_bytes + compute_bereq_header_bytes + compute_bereq_body_bytes + websocket_resp_header_bytes + websocket_resp_body_bytes + websocket_bereq_header_bytes + websocket_bereq_body_bytes).
bereq_body_bytesintegerTotal body bytes sent to origin.
bereq_header_bytesintegerTotal header bytes sent to origin.
body_sizeintegerTotal body bytes delivered (alias for resp_body_bytes).
compute_bereq_body_bytesintegerTotal body bytes sent to backends (origins) by Compute@Edge.
compute_bereq_errorsintegerNumber of backend request errors, including timeouts.
compute_bereq_header_bytesintegerTotal header bytes sent to backends (origins) by Compute@Edge.
compute_bereqsintegerNumber of backend requests started.
compute_beresp_body_bytesintegerTotal body bytes received from backends (origins) by Compute@Edge.
compute_beresp_header_bytesintegerTotal header bytes received from backends (origins) by Compute@Edge.
compute_execution_time_msnumberThe amount of active CPU time used to process your requests (in milliseconds).
compute_globals_limit_exceededintegerNumber of times a guest exceeded its globals limit.
compute_guest_errorsintegerNumber of times a service experienced a guest code error.
compute_heap_limit_exceededintegerNumber of times a guest exceeded its heap limit.
compute_ram_usedintegerThe amount of RAM used for your service by Fastly (in bytes).
compute_req_body_bytesintegerTotal body bytes received by Compute@Edge.
compute_req_header_bytesintegerTotal header bytes received by Compute@Edge.
compute_request_time_msnumberThe total, actual amount of time used to process your requests, including active CPU time (in milliseconds).
compute_requestsintegerThe total number of requests that were received for your service by Fastly.
compute_resource_limit_exceededintegerNumber of times a guest exceeded its resource limit, includes heap, stack, globals, and code execution timeout.
compute_resp_body_bytesintegerTotal body bytes sent from Compute@Edge to end user.
compute_resp_header_bytesintegerTotal header bytes sent from Compute@Edge to end user.
compute_resp_status_1xxintegerNumber of "Informational" category status codes delivered by Compute@Edge.
compute_resp_status_2xxintegerNumber of "Success" category status codes delivered by Compute@Edge.
compute_resp_status_3xxintegerNumber of "Redirection" category status codes delivered by Compute@Edge.
compute_resp_status_4xxintegerNumber of "Client Error" category status codes delivered by Compute@Edge.
compute_resp_status_5xxintegerNumber of "Server Error" category status codes delivered by Compute@Edge.
compute_runtime_errorsintegerNumber of times a service experienced a guest runtime error.
compute_stack_limit_exceededintegerNumber of times a guest exceeded its stack limit.
deliver_sub_countintegerNumber of executions of the vcl_deliver Varnish subroutine.
deliver_sub_timenumberTime spent inside the vcl_deliver Varnish subroutine (in seconds).
edge_hit_requestsintegerNumber of requests sent by end users to Fastly that resulted in a hit at the edge.
edge_hit_resp_body_bytesintegerBody bytes delivered for edge hits.
edge_hit_resp_header_bytesintegerHeader bytes delivered for edge hits.
edge_miss_requestsintegerNumber of requests sent by end users to Fastly that resulted in a miss at the edge.
edge_miss_resp_body_bytesintegerBody bytes delivered for edge misses.
edge_miss_resp_header_bytesintegerHeader bytes delivered for edge misses.
edge_requestsintegerNumber of requests sent by end users to Fastly.
edge_resp_body_bytesintegerTotal body bytes delivered from Fastly to the end user.
edge_resp_header_bytesintegerTotal header bytes delivered from Fastly to the end user.
error_sub_countintegerNumber of executions of the vcl_error Varnish subroutine.
error_sub_timenumberTime spent inside the vcl_error Varnish subroutine (in seconds).
errorsintegerNumber of cache errors.
fanout_bereq_body_bytesintegerTotal body or message content bytes sent to backends over Fanout connections.
fanout_bereq_header_bytesintegerTotal header bytes sent to backends over Fanout connections.
fanout_beresp_body_bytesintegerTotal body or message content bytes received from backends over Fanout connections.
fanout_beresp_header_bytesintegerTotal header bytes received from backends over Fanout connections.
fanout_conn_time_msintegerTotal duration of Fanout connections with end users.
fanout_recv_publishesintegerTotal published messages received from the publish API endpoint.
fanout_req_body_bytesintegerTotal body or message content bytes received from end users over Fanout connections.
fanout_req_header_bytesintegerTotal header bytes received from end users over Fanout connections.
fanout_resp_body_bytesintegerTotal body or message content bytes sent to end users over Fanout connections, excluding published message content.
fanout_resp_header_bytesintegerTotal header bytes sent to end users over Fanout connections.
fanout_send_publishesintegerTotal published messages sent to end users.
fetch_sub_countintegerNumber of executions of the vcl_fetch Varnish subroutine.
fetch_sub_timenumberTime spent inside the vcl_fetch Varnish subroutine (in seconds).
hash_sub_countintegerNumber of executions of the vcl_hash Varnish subroutine.
hash_sub_timenumberTime spent inside the vcl_hash Varnish subroutine (in seconds).
header_sizeintegerTotal header bytes delivered (alias for resp_header_bytes).
hit_rationumberRatio of cache hits to cache misses (between 0 and 1).
hit_resp_body_bytesintegerTotal body bytes delivered for cache hits.
hit_sub_countintegerNumber of executions of the vcl_hit Varnish subroutine.
hit_sub_timenumberTime spent inside the vcl_hit Varnish subroutine (in seconds).
hitsintegerNumber of cache hits.
hits_timenumberTotal amount of time spent processing cache hits (in seconds).
http2integerNumber of requests received over HTTP/2.
http3integerNumber of requests received over HTTP/3.
imgoptointegerNumber of responses that came from the Fastly Image Optimizer service. If the service receives 10 requests for an image, this stat will be 10 regardless of how many times the image was transformed.
imgopto_resp_body_bytesintegerTotal body bytes delivered from the Fastly Image Optimizer service, including shield traffic.
imgopto_resp_header_bytesintegerTotal header bytes delivered from the Fastly Image Optimizer service, including shield traffic.
imgopto_shield_resp_body_bytesintegerTotal body bytes delivered via a shield from the Fastly Image Optimizer service.
imgopto_shield_resp_header_bytesintegerTotal header bytes delivered via a shield from the Fastly Image Optimizer service.
imgvideointegerNumber of video responses that came from the Fastly Image Optimizer service.
imgvideo_framesintegerNumber of video frames that came from the Fastly Image Optimizer service. A video frame is an individual image within a sequence of video.
imgvideo_resp_body_bytesintegerTotal body bytes of video delivered from the Fastly Image Optimizer service.
imgvideo_resp_header_bytesintegerTotal header bytes of video delivered from the Fastly Image Optimizer service.
imgvideo_shieldintegerNumber of video responses delivered via a shield that came from the Fastly Image Optimizer service.
imgvideo_shield_framesintegerNumber of video frames delivered via a shield that came from the Fastly Image Optimizer service. A video frame is an individual image within a sequence of video.
imgvideo_shield_resp_body_bytesintegerTotal body bytes of video delivered via a shield from the Fastly Image Optimizer service.
imgvideo_shield_resp_header_bytesintegerTotal header bytes of video delivered via a shield from the Fastly Image Optimizer service.
ipv6integerNumber of requests that were received over IPv6.
logintegerNumber of log lines sent.
log_bytesintegerTotal log bytes sent.
missintegerNumber of cache misses.
miss_resp_body_bytesintegerTotal body bytes delivered for cache misses.
miss_sub_countintegerNumber of executions of the vcl_miss Varnish subroutine.
miss_sub_timenumberTime spent inside the vcl_miss Varnish subroutine (in seconds).
miss_timenumberTotal amount of time spent processing cache misses (in seconds).
object_size_100kintegerNumber of objects served that were between 10KB and 100KB in size.
object_size_100mintegerNumber of objects served that were between 10MB and 100MB in size.
object_size_10kintegerNumber of objects served that were between 1KB and 10KB in size.
object_size_10mintegerNumber of objects served that were between 1MB and 10MB in size.
object_size_1gintegerNumber of objects served that were between 100MB and 1GB in size.
object_size_1kintegerNumber of objects served that were under 1KB in size.
object_size_1mintegerNumber of objects served that were between 100KB and 1MB in size.
object_store_read_requestsintegerThe total number of reads received for the object store.
object_store_write_requestsintegerThe total number of writes received for the object store.
origin_cache_fetch_resp_body_bytesintegerBody bytes received from origin for cacheable content.
origin_cache_fetch_resp_header_bytesintegerHeader bytes received from an origin for cacheable content.
origin_cache_fetchesintegerThe total number of completed requests made to backends (origins) that returned cacheable content.
origin_fetch_body_bytesintegerTotal request body bytes sent to origin.
origin_fetch_header_bytesintegerTotal request header bytes sent to origin.
origin_fetch_resp_body_bytesintegerTotal body bytes received from origin.
origin_fetch_resp_header_bytesintegerTotal header bytes received from origin.
origin_fetchesintegerNumber of requests sent to origin.
origin_revalidationsintegerNumber of responses received from origin with a 304 status code in response to an If-Modified-Since or If-None-Match request. Under regular scenarios, a revalidation will imply a cache hit. However, if using Fastly Image Optimizer or segmented caching this may result in a cache miss.
otfpintegerNumber of responses that came from the Fastly On-the-Fly Packaging service for video-on-demand.
otfp_deliver_timenumberTotal amount of time spent delivering a response from the Fastly On-the-Fly Packaging service for video-on-demand (in seconds).
otfp_manifestsintegerNumber of responses that were manifest files from the Fastly On-the-Fly Packaging service for video-on-demand.
otfp_resp_body_bytesintegerTotal body bytes delivered from the Fastly On-the-Fly Packaging service for video-on-demand.
otfp_resp_header_bytesintegerTotal header bytes delivered from the Fastly On-the-Fly Packaging service for video-on-demand.
otfp_shield_resp_body_bytesintegerTotal body bytes delivered via a shield for the Fastly On-the-Fly Packaging service for video-on-demand.
otfp_shield_resp_header_bytesintegerTotal header bytes delivered via a shield for the Fastly On-the-Fly Packaging service for video-on-demand.
otfp_shield_timenumberTotal amount of time spent delivering a response via a shield from the Fastly On-the-Fly Packaging service for video-on-demand (in seconds).
passintegerNumber of requests that passed through the CDN without being cached.
pass_resp_body_bytesintegerTotal body bytes delivered for cache passes.
pass_sub_countintegerNumber of executions of the vcl_pass Varnish subroutine.
pass_sub_timenumberTime spent inside the vcl_pass Varnish subroutine (in seconds).
pass_timenumberTotal amount of time spent processing cache passes (in seconds).
pciintegerNumber of responses with the PCI flag turned on.
pipeintegerOptional. Pipe operations performed (legacy feature).
pipe_sub_countintegerNumber of executions of the vcl_pipe Varnish subroutine.
pipe_sub_timenumberTime spent inside the vcl_pipe Varnish subroutine (in seconds).
predeliver_sub_countintegerNumber of executions of the vcl_predeliver Varnish subroutine.
predeliver_sub_timenumberTime spent inside the vcl_predeliver Varnish subroutine (in seconds).
prehash_sub_countintegerNumber of executions of the vcl_prehash Varnish subroutine.
prehash_sub_timenumberTime spent inside the vcl_prehash Varnish subroutine (in seconds).
recv_sub_countintegerNumber of executions of the vcl_recv Varnish subroutine.
recv_sub_timenumberTime spent inside the vcl_recv Varnish subroutine (in seconds).
req_body_bytesintegerTotal body bytes received.
req_header_bytesintegerTotal header bytes received.
requestsintegerNumber of requests processed.
resp_body_bytesintegerTotal body bytes delivered (edge_resp_body_bytes + shield_resp_body_bytes).
resp_header_bytesintegerTotal header bytes delivered (edge_resp_header_bytes + shield_resp_header_bytes).
restartsintegerNumber of restarts performed.
segblock_origin_fetchesintegerNumber of Range requests to origin for segments of resources when using segmented caching.
segblock_shield_fetchesintegerNumber of Range requests to a shield for segments of resources when using segmented caching.
shieldintegerNumber of requests from edge to the shield POP.
shield_cache_fetchesintegerThe total number of completed requests made to shields that returned cacheable content.
shield_fetch_body_bytesintegerTotal request body bytes sent to a shield.
shield_fetch_header_bytesintegerTotal request header bytes sent to a shield.
shield_fetch_resp_body_bytesintegerTotal response body bytes sent from a shield to the edge.
shield_fetch_resp_header_bytesintegerTotal response header bytes sent from a shield to the edge.
shield_fetchesintegerNumber of requests made from one Fastly POP to another, as part of shielding.
shield_hit_requestsintegerNumber of requests that resulted in a hit at a shield.
shield_hit_resp_body_bytesintegerBody bytes delivered for shield hits.
shield_hit_resp_header_bytesintegerHeader bytes delivered for shield hits.
shield_miss_requestsintegerNumber of requests that resulted in a miss at a shield.
shield_miss_resp_body_bytesintegerBody bytes delivered for shield misses.
shield_miss_resp_header_bytesintegerHeader bytes delivered for shield misses.
shield_resp_body_bytesintegerTotal body bytes delivered via a shield.
shield_resp_header_bytesintegerTotal header bytes delivered via a shield.
shield_revalidationsintegerNumber of responses received from origin with a 304 status code, in response to an If-Modified-Since or If-None-Match request to a shield. Under regular scenarios, a revalidation will imply a cache hit. However, if using segmented caching this may result in a cache miss.
status_1xxintegerNumber of "Informational" category status codes delivered.
status_200integerNumber of responses sent with status code 200 (Success).
status_204integerNumber of responses sent with status code 204 (No Content).
status_206integerNumber of responses sent with status code 206 (Partial Content).
status_2xxintegerNumber of "Success" status codes delivered.
status_301integerNumber of responses sent with status code 301 (Moved Permanently).
status_302integerNumber of responses sent with status code 302 (Found).
status_304integerNumber of responses sent with status code 304 (Not Modified).
status_3xxintegerNumber of "Redirection" codes delivered.
status_400integerNumber of responses sent with status code 400 (Bad Request).
status_401integerNumber of responses sent with status code 401 (Unauthorized).
status_403integerNumber of responses sent with status code 403 (Forbidden).
status_404integerNumber of responses sent with status code 404 (Not Found).
status_406integerNumber of responses sent with status code 406 (Not Acceptable).
status_416integerNumber of responses sent with status code 416 (Range Not Satisfiable).
status_429integerNumber of responses sent with status code 429 (Too Many Requests).
status_4xxintegerNumber of "Client Error" codes delivered.
status_500integerNumber of responses sent with status code 500 (Internal Server Error).
status_501integerNumber of responses sent with status code 501 (Not Implemented).
status_502integerNumber of responses sent with status code 502 (Bad Gateway).
status_503integerNumber of responses sent with status code 503 (Service Unavailable).
status_504integerNumber of responses sent with status code 504 (Gateway Timeout).
status_505integerNumber of responses sent with status code 505 (HTTP Version Not Supported).
status_5xxintegerNumber of "Server Error" codes delivered.
synthintegerNumber of requests that returned a synthetic response (i.e., response objects created with the synthetic VCL statement).
tlsintegerNumber of requests that were received over TLS.
tls_handshake_sent_bytesintegerNumber of bytes transferred during TLS handshake.
tls_v10integerNumber of requests received over TLS 1.0.
tls_v11integerNumber of requests received over TLS 1.1.
tls_v12integerNumber of requests received over TLS 1.2.
tls_v13integerNumber of requests received over TLS 1.3.
uncacheableintegerNumber of requests that were designated uncachable.
videointegerNumber of responses with the video segment or video manifest MIME type (i.e., application/x-mpegurl, application/vnd.apple.mpegurl, application/f4m, application/dash+xml, application/vnd.ms-sstr+xml, ideo/mp2t, audio/aac, video/f4f, video/x-flv, video/mp4, audio/mp4).
waf_blockedintegerNumber of requests that triggered a WAF rule and were blocked.
waf_loggedintegerNumber of requests that triggered a WAF rule and were logged.
waf_passedintegerNumber of requests that triggered a WAF rule and were passed.
websocket_bereq_body_bytesintegerTotal message content bytes sent to backends over passthrough WebSocket connections.
websocket_bereq_header_bytesintegerTotal header bytes sent to backends over passthrough WebSocket connections.
websocket_beresp_body_bytesintegerTotal message content bytes received from backends over passthrough WebSocket connections.
websocket_beresp_header_bytesintegerTotal header bytes received from backends over passthrough WebSocket connections.
websocket_conn_time_msintegerTotal duration of passthrough WebSocket connections with end users.
websocket_req_body_bytesintegerTotal message content bytes received from end users over passthrough WebSocket connections.
websocket_req_header_bytesintegerTotal header bytes received from end users over passthrough WebSocket connections.
websocket_resp_body_bytesintegerTotal message content bytes sent to end users over passthrough WebSocket connections.
websocket_resp_header_bytesintegerTotal header bytes sent to end users over passthrough WebSocket connections.

Endpoints

Get historical stats

GET/stats

Get historical stats for a single field

GET/stats/field/field

Get aggregated historical stats

GET/stats/aggregate

Get historical stats for a single service

GET/stats/service/service_id

Get historical stats for a single service/field combination

GET/stats/service/service_id/field/field

Get usage statistics

GET/stats/usage

Get usage statistics per service

GET/stats/usage_by_service

Get month-to-date usage statistics

GET/stats/usage_by_month

Get region codes

GET/stats/regions