Skip to main content

API Tokens

API tokens (Bearer tokens) enable you to access Netdata resources programmatically. These tokens authenticate and authorize API requests, allowing you to interact with Netdata services securely from external applications, scripts, or integrations.

important

API tokens never expire but should be managed carefully as they grant access to your Netdata resources.

Token Generation

Location

You can access token management through the Netdata UI:

  1. Click your profile picture in the bottom-left corner
  2. Select "User Settings"
  3. Navigate to the API Tokens section

Available Scopes

You can limit each token to specific scopes that define its access permissions:

ScopeDescriptionAPI Access
scope:allGrants the same permissions as the user who created the token. Use case: Terraform provider integration.Full access to all API endpoints
scope:agent-uiUsed by Agent for accessing the Cloud UIAccess to UI-related endpoints
scope:grafana-pluginUsed for the Netdata Grafana plugin to access Netdata chartsAccess to chart and data endpoints
scope:mcpUsed to connect MCP clients (Claude Desktop, Cursor, etc.) to Netdata Cloud MCP for AI-assisted monitoringAccess to MCP server endpoints

API Versions

Netdata provides three API versions that you can access with API tokens:

  • v1: The original API, focused on single-node operations
  • v2: Multi-node API with advanced grouping and aggregation capabilities
  • v3: The latest API version that combines v1 and v2 endpoints and may include additional features
tip

v3 is the recommended version for Netdata Cloud queries. Netdata Cloud v3 endpoints use POST with a JSON body and provide the most control over scoping, filtering, and aggregation. Local Agent v3 endpoints are available via GET; for example, /api/v3/data is query-parameter driven and does not use the Cloud v3 JSON body shape. See the Common Endpoints section for v3 endpoint details.

Common Endpoints

With the appropriate token type, you can access endpoints including: Cloud API tokens authenticate Netdata Cloud endpoints, while direct Local Agent endpoints use per-agent bearer tokens only when Agent bearer protection is enabled (and may not require a token when unprotected).

SurfaceMethodEndpointPurpose
Netdata CloudPOST/api/v3/spaces/{spaceID}/rooms/{roomID}/dataTime-series metric data queries
Netdata CloudPOST/api/v3/spaces/{spaceID}/rooms/{roomID}/nodesList nodes in a room
Netdata CloudPOST/api/v3/spaces/{spaceID}/rooms/{roomID}/contextsList available metric contexts
Local AgentGET/api/v3/datav3 data queries (single-node on an Agent, multi-node on a Parent)
Local AgentGET/api/v3/nodesMulti-host node listing on a parent Agent
Local AgentGET/api/v3/contextsList available metric contexts on an Agent
Local AgentGET/api/v3/weightsMetric scoring/correlation
Local AgentGET/api/v3/qFull-text search
Netdata Cloud, Local AgentGET/api/v2/nodesNode information
Netdata Cloud, Local AgentGET/api/v2/dataMulti-dimensional data queries
Netdata Cloud, Local AgentGET/api/v2/contextsContext metadata
Netdata Cloud, Local AgentGET/api/v2/weightsMetric scoring/correlation
Netdata Cloud, Local AgentGET/api/v2/qFull-text search
Local AgentGET/api/v1/infoAgent information
Local AgentGET/api/v1/chartsLegacy chart information
Local AgentGET/api/v1/dataLegacy single-node data queries
caution

The local Agent /api/v1/charts endpoint is still available for backward compatibility, but it is deprecated for new integrations. Use /api/v3/contexts on local Agents, or /api/v3/spaces/{spaceID}/rooms/{roomID}/contexts in Netdata Cloud, to discover current metric contexts and dimensions.

note

For Netdata Cloud metric queries, use the room-scoped v3 POST endpoints with a JSON body. Local Agents expose their own unscoped v3 endpoints such as /api/v3/data, /api/v3/nodes, /api/v3/contexts, /api/v3/weights, and /api/v3/q. Legacy metrics v1 endpoints such as /api/v1/data and /api/v1/charts remain local-Agent only and return 404 when called against app.netdata.cloud. v2 endpoints work on both Cloud and local Agents for backward compatibility, but v3 is recommended for Cloud.

Example Usage

Get the Netdata Cloud space list

curl -H 'Accept: application/json' -H "Authorization: Bearer <token>" https://app.netdata.cloud/api/v2/spaces

Get node information

curl -H 'Accept: application/json' -H "Authorization: Bearer <token>" https://app.netdata.cloud/api/v2/nodes

Query metric data

curl -H 'Accept: application/json' -H "Authorization: Bearer <token>" https://app.netdata.cloud/api/v2/data?contexts=system.cpu&after=-600
tip

The examples above use v2 endpoints. For metric data queries, the v3 equivalent (/api/v3/data) is also available on local Agents and is used with query parameters. On Netdata Cloud, use the room-scoped v3 POST endpoint and JSON body — see the Advanced Metric Queries example below.

Advanced Metric Queries with Aggregation

For more advanced queries with aggregation, use the POST endpoint with a JSON body. This allows you to query metrics with time aggregation (like average values) and control grouping and filtering.

TOKEN="YOUR_API_TOKEN"
SPACE="YOUR_SPACE_ID"
ROOM="YOUR_ROOM_ID"

read -r -d '' PAYLOAD <<'EOF'
{
"scope": {"contexts": ["system.cpu"]},
"selectors": {"nodes": ["*"], "contexts": ["*"], "instances": ["*"], "dimensions": ["*"], "labels": ["*"], "alerts": ["*"]},
"window": {"after": -600, "before": 0, "points": 5},
"aggregations": {
"metrics": [{"group_by": ["selected"], "aggregation": "sum"}],
"time": {"time_group": "average"}
},
"format": "json2",
"options": ["jsonwrap", "minify", "unaligned"],
"timeout": 30000
}
EOF

curl -s -X POST \
-H 'Content-Type: application/json' \
-H "Authorization: Bearer $TOKEN" \
"https://app.netdata.cloud/api/v3/spaces/$SPACE/rooms/$ROOM/data" \
-d "$PAYLOAD"

Time Aggregation Options

The time_group parameter in aggregations.time controls how data points within each time interval are combined:

OptionDescriptionUse Case
averageMean value (default)Average resource consumption over time
minMinimum valueFind lowest values in each interval
maxMaximum valueFind spikes or peaks
sumSum of valuesTotal volume transferred (counters)
medianMedian valueRobust central tendency
stddevStandard deviationMeasure of variability
sesSingle exponential smoothingTrend-aware smoothing
desDouble exponential smoothingTrend + seasonality smoothing
incremental-sumDifference between last and first valueChange over interval
percentileGeneric percentile (set value in time_group_options)e.g., 95th percentile latency
countifCount values matching condition (set condition in time_group_options)e.g., count samples above threshold
trimmed-meanMean after trimming outliers (set trim % in time_group_options)Robust average excluding extremes
trimmed-medianMedian after trimming outliers (set trim % in time_group_options)Robust median excluding extremes
extremesMin and max valuesShow value range per interval
important

When using time_group values other than min, max, average, or sum, you MUST specify "tier": 0 in the window object to ensure a non-aggregated storage tier is used. Without it, the query may use a pre-aggregated tier (per-minute or per-hour) where advanced functions like median, stddev, ses, des, percentile, countif, trimmed-mean, trimmed-median, and extremes cannot work correctly.

Get context information

curl -H 'Accept: application/json' -H "Authorization: Bearer <token>" https://app.netdata.cloud/api/v2/contexts

Do you have any feedback for this page? If so, you can open a new issue on our netdata/learn repository.