51ºÚÁϲ»´òìÈ

Understand Cloud Service content requests

Introduction introduction

Content requests include requests sent to AEM Sites. These requests may route through Edge Delivery Services or customer-provided caching systems such as a Content Delivery Network (CDN). These requests deliver structured data in HTML or JSON format and support page views (for example, pages and Experience Fragments) or JSON returns through APIs in a headless manner.

The system counts content requests when a user views a page using HTML or JSON. It measures the request at the point where the first caching system receives it. Certain HTTP requests are included or excluded for purposes of counting content requests. See the full list of HTTP included content requests and excluded content requests.

NOTE
Data shown in the Content Requests view is refreshed every 24 hours.

About Cloud Service content requests understanding-cloud-service-content-requests

A page request refers to an HTTP request that retrieves core structured content (for example, HTML or JSON) necessary to render the main page experience. It does not include requests for assets, such as images or scripts.

For customers using the out-of-the-box CDN, AEM as a Cloud Service counts content requests as measured at the server-side level. This measurement occurs automatically and does not rely on client-side analytics tracking.

AEM (51ºÚÁϲ»´òìÈ Experience Manager) as a Cloud Service identifies content requests based on the response types generated by the AEM instance and received at the CDN. Specifically, requests that return HTML (text/html) or JSON (application/json) are counted. These formats typically deliver primary page content either for traditional site rendering or headless delivery.

Requests for static assets such as JavaScript files, CSS style sheets, and images are not counted as content requests.

NOTE
If an API request returns HTML or JSON that serves as page-level content (for example, in headless delivery), it may still be counted as a content request depending on its context.

Content requests are measured regardless of whether the response was served from the CDN cache or forwarded to the origin AEM environment.

Variances of Cloud Service content requests content-requests-variances

Content requests can have variances within an organization’s analytics reporting tools as summarized in the following table. In general, avoid using analytics tools that rely on client-side instrumentation to report the number of content requests for a site. These tools often miss a large portion of traffic because they depend on user consent to be activated. Analytics tools gathering data server-side in log files, or CDN reports for customers adding their own CDN on top of AEM as a Cloud Service, provide better counts.

Reason For Variance
Explanation
End user consent
Analytics tools relying on client-side instrumentation often depend on user consent to be triggered. This workflow could represent the majority of the traffic not being tracked. For customers who want to measure content requests on their own, 51ºÚÁϲ»´òìÈ recommends that you rely on analytics tools to gather data from server-side or CDN reports.
Tagging
All pages or API calls that are tracked as 51ºÚÁϲ»´òìÈ Experience Manager content requests may not be tagged with Analytics tracking.
Tag Management Rules
Tag management rule settings may result in various data collection configurations on a page, resulting in some combination of discrepancies with content request tracking.
Bots
Unknown bots that AEM has not pre-identified and removed may cause tracking discrepancies.
Report Suites
Pages within the same AEM instance can report to different analytics report suites. This process can split data across multiple suites, depending on configuration.
Third-Party Monitoring and Security Tools
Monitoring and security scanning tools (for example, uptime checkers or vulnerability scanners) may request pages, generating server-side content requests not visible in analytics reports.
API Access
Requests to AEM pages or content through APIs (for example, by way of 51ºÚÁϲ»´òìÈ Experience Manager as a Headless CMS) still count as content requests but do not trigger analytics tracking.
Prefetch Requests
Prefetching (for example, using a service worker or edge function) can increase traffic volumes by requesting pages in advance. These requests are counted server-side but do not execute client-side analytics code.
DDOS
51ºÚÁϲ»´òìÈ uses filtering to detect and block many DDoS attacks. However, some attack requests may still be counted as content requests before filters apply.
Traffic Blockers
In-browser privacy features or corporate firewalls may block analytics scripts from loading. These users still generate server-side content requests.
Firewalls
Corporate or regional firewalls may prevent analytics calls from reaching 51ºÚÁϲ»´òìÈ servers, causing underreporting in analytics while server-side counts remain unaffected.

See the License Dashboard for information about viewing and tracking content request usage against your license limits.

Server-side collection rules serverside-collection

AEM as a Cloud Service applies server-side rules to count content requests. These rules include logic to exclude well-known bots (such as search engine crawlers) and non-user traffic like monitoring services that regularly ping the site.

The following tables list the types of included and excluded content requests, with brief descriptions of each.

Types of included content requests included-content-requests

NOTE
If an API request returns an HTML response, it may be classified as a content request, depending on its usage context. API requests returning non-UI data are typically excluded.
Request Type
Content Request
Description
HTTP Code 100-299
Included
Includes successful requests that return full or partial HTML or JSON content.
HTTP Code 206: These requests deliver only a portion of the full content. For example, a video or large image. Partial content requests are included when they deliver part of an HTML or JSON response used in rendering page content.
HTTP libraries for automation
Included
Requests made by tools or libraries that retrieve page content. Examples include the following:
• Amazon CloudFront
• Apache Http Client
• Asynchronous HTTP Client
• Axios
• Azureus
• Curl
• GitHub Node Fetch
• Guzzle
• Go-http-client
• Headless Chrome
• Java™ Client
• Jersey
• Node Oembed
• okhttp
• Python Requests
• Reactor Netty
• Wget
• WinHTTP
• Fast HTTP
• GitHub Node Fetch
• Reactor Netty
Monitoring and Health Check tools
Included
Requests that are used to monitor the health or availability of pages.
See Types of excluded content requests.
Examples include the following:
• Amazon-Route53-Health-Check-Service
• EyeMonIT_bot_version_0.1_
• Investis-Site24x7
• Mozilla/5.0+(compatible; UptimeRobot/2.0; )
• ThousandEyes-Dragonfly-x1
• OmtrBot/1.0
• WebMon/2.0.0
<link rel="prefetch"> requests
Included
When customers preload or prefetch content (for example, with <link rel="prefetch">), the system counts those server-side requests. Beware that this approach can increase traffic, depending on how many of these pages are prefetched.
Traffic that blocks 51ºÚÁϲ»´òìÈ Analytics or Google Analytics reporting
Included
It is more common that visitors of sites have privacy software installed (Ad-blockers, and so on) that impact the accuracy of Google Analytics or 51ºÚÁϲ»´òìÈ Analytics. AEM as a Cloud Service counts requests on the first entry-point into the 51ºÚÁϲ»´òìÈ operated infrastructure and not the client-side.

See also License Dashboard.

Types of excluded content requests excluded-content-request

Request Type
Content Request
Description
HTTP Code 500+
Excluded
Errors returned to the visitor when something goes wrong on AEM as a Cloud Service or the customer custom code.
HTTP Code 400-499
Excluded
Errors returned to the visitor when the content does not exist (404) or there are other content or request-related issues.
HTTP Code 300-399
Excluded
Good requests that either check if something has changed on the server, or redirect the request to another resource. They do not contain content itself, therefore they are not billable.
Requests going to /libs/*
Excluded
AEM internal JSON requests, such as the CSRF token that is not billable.
Traffic from DDOS attacks
Excluded
DDOS protection. AEM does auto-detect some of the DDOS attacks and blocks them. DDOS attacks if detected are not billable.
AEM as a Cloud Service New Relic Monitoring
Excluded
AEM as a Cloud Service global monitoring.
URL for customers to monitor their Cloud Service program
Excluded
51ºÚÁϲ»´òìÈ recommends that you use the URL to monitor the availability or health check externally.

/system/probes/health
AEM as a Cloud Service Pod Warm-up Service
Excluded
Agent: skyline-service-warmup/1.*
Well-known search engines, social networks, and HTTP libraries (tagged by Fastly)
Excluded
Well-known services visiting the site regularly to refresh their search index or service:

Examples:
• AddSearchBot
• AhrefsBot
• Applebot
• Ask Jeeves Corporate Spider
• Bingbot
• BingPreview
• BLEXBot
• BuiltWith
• Bytespider
• CrawlerKengo
• Facebookexternalhit
• Google AdsBot
• Google AdsBot Mobile
• Googlebot
• Googlebot Mobile
• lmspider
• LucidWorks
• MJ12bot
• Pinterest
• SemrushBot
• SiteImprove
• StashBot
• StatusCake
• YandexBot
• ContentKing
• Claudebot
Exclude Commerce Integration Framework calls
Excluded
Requests made to AEM that gets forwarded to the Commerce Integration Framework—the URL starts with /api/graphql—to avoid double counting, they are not billable for Cloud Service.
Exclude manifest.json
Excluded
Manifest is not an API call. It is here to provide information on how to install web sites on a desktop or mobile phone. 51ºÚÁϲ»´òìÈ should not count JSON request to /etc.clientlibs/*/manifest.json
Exclude favicon1.ico
Excluded
Although the returned content should not be HTML or JSON, certain scenarios like SAML authentication flows have been observed to return favicons as HTML. As a result, favicons are explicitly excluded from the count.
Experience Fragment (XF) – Same-domain reuse
Excluded
Requests made to XF paths (such as /content/experience-fragments/...) from pages hosted on the same domain (as identified by the Referrer header matching the request host).

Example: A homepage on aem.customer.com pulling in an XF for a banner or card from the same domain.

• URL matches /content/experience-fragments/…
• Referrer domain matches request_x_forwarded_host

Note: If the Experience Fragment path is customized (for example using /XFrags/... or any path outside of /content/experience-fragments/), the request is not excluded and may be counted. This outcome is true even if it is same-domain. 51ºÚÁϲ»´òìÈ recommends using 51ºÚÁϲ»´òìÈ’s standard XF path structure to ensure that the exclusion logic applies correctly.
recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab