Metrics and GraphQL analytics
Durable Objects expose analytics for Durable Object namespace-level and request-level metrics.
The metrics displayed in the Cloudflare dashboard ↗ charts are queried from Cloudflare’s GraphQL Analytics API. You can access the metrics programmatically via GraphQL or HTTP client.
Per-namespace analytics for Durable Objects are available in the Cloudflare dashboard. To view current and historical metrics for a namespace:
- Log in to the Cloudflare dashboard ↗ and select your account.
- Go to Workers & Pages > Durable Objects ↗.
- View account-level Durable Objects usage.
- Select an existing namespace.
- Select the Metrics tab.
You can optionally select a time window to query. This defaults to the last 24 hours.
Durable Object metrics are powered by GraphQL.
The datasets that include Durable Object metrics include:
- durableObjectsInvocationsAdaptiveGroups
- durableObjectsPeriodicGroups
- durableObjectsStorageGroups
- durableObjectsSubrequestsAdaptiveGroups
Use GraphQL Introspection to get information on the fields exposed by each datasets.
Durable Objects using WebSockets will see request metrics across several GraphQL datasets because WebSockets have different types of requests.
- Metrics for a WebSocket connection itself is represented in durableObjectsInvocationsAdaptiveGroupsonce the connection closes. Since WebSocket connections are long-lived, connections often do not terminate until the Durable Object terminates.
- Metrics for incoming and outgoing WebSocket messages on a WebSocket connection are available in durableObjectsPeriodicGroups. If a WebSocket connection uses WebSocket Hibernation, incoming WebSocket messages are instead represented indurableObjectsInvocationsAdaptiveGroups.
  viewer {    /*    Replace with your account tag, the 32 hex character id visible at the beginning of any url    when logged in to dash.cloudflare.com or under "Account ID" on the sidebar of the Workers & Pages Overview    */    accounts(filter: {accountTag: "your account tag here"}) {      // Replace dates with a recent date      durableObjectsInvocationsAdaptiveGroups(filter: {date_gt: "2023-05-23"}, limit: 1000) {        sum {          // Any other fields found through introspection can be added here          requests          responseBodySize        }      }      durableObjectsPeriodicGroups(filter: {date_gt: "2023-05-23"}, limit: 1000) {        sum {          cpuTime        }      }      durableObjectsStorageGroups(filter: {date_gt: "2023-05-23"}, limit: 1000) {        max {          storedBytes        }      }    }  }Refer to the Querying Workers Metrics with GraphQL tutorial for authentication and to learn more about querying Workers datasets.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark