Customer Metrics Integration (CMI)
AuraDB Virtual Dedicated Cloud AuraDS Enterprise AuraDB Business Critical
An application performance monitoring system can be configured to fetch metrics of AuraDB instances of types:
- 
AuraDB Virtual Dedicated Cloud 
- 
AuraDS Enterprise 
- 
AuraDB Business Critical 
This gives users access to their Neo4j Aura instance metric data for monitoring purposes.
Analyzing the metrics data allows users to:
- 
Optimize their Neo4j workload 
- 
Adjust Aura instance sizing 
- 
Set up notifications 
| Aura Database and Analytics services are business-critical for users. There are requests to introduce more capabilities enabling access to logs and metrics to derive actionable insights using your choice of monitoring platform. Aura has a strong roadmap of observability sharing features including security logs, query logs, and other capabilities. Customer metrics integration requires transmitting a significant amount of data, hence a new consumption-based billing model including cloud egress costs will be introduced in the future. Observability is of paramount importance, and therefore the customer metrics integration is initially available for free. | 
Integration Process overview
 
Detailed Aura CMI setup steps and APM integration examples are described in the next chapters.
Security
Metrics for a Neo4j Aura instance are only returned if all the following are true:
- 
Authorizationheader of the metrics request contains a valid token.
- 
The token was issued for an Aura user with the Metrics Reader role. 
- 
Project has instances of types Enterprise (Virtual Dedicated Cloud)orBusiness Critical.
- 
The specified instance belongs to the specified project. 
| The legacy term  | 
To revoke a user’s access to metrics of a specific project, remove the user from that project in Project > Users .
After that, the user still exists but its connection to the project is removed.
| The revocation described takes effect after the authorization caches expire, which takes approximately 5 minutes.
It results in HTTP 401 being returned, along with the message  | 
Metric details
Depending on the metric, the following labels are applied:
- 
aggregation: the aggregation used to calculate the metric value, set on every metric. Since the Neo4j instance is deployed as a Neo4j cluster, aggregations are performed to combine values from all relevant cluster nodes. The following aggregations are used:MIN,MAX,AVGandSUM.
- 
instance_id: the Aura instance ID the metric is reported for, set on every metric.
- 
database: the name of the Neo4j database the metric is reported for. Set toneo4jby default.
# HELP neo4j_database_count_node The total number of nodes in the database.
# TYPE neo4j_database_count_node gauge
neo4j_database_count_node{aggregation="MAX",database="neo4j",instance_id="78e7c3e0"} 778114.000000 1711462853000Metrics reference is provided here.
Metric scrape interval
The recommended scrape interval for metrics is in the range of 30 seconds up to 2 minutes, depending on requirements. The metrics endpoint caches metrics for 30 seconds.
Metric scrape timeout
The recommended scrape timeout for metrics is 30 seconds.
Examples of setting scrape timeout for different APM systems:
- 
Prometheus: scrape_timeout: 30s(see Prometheus configuration reference)
- 
Datadog: timeout: 30(see Datadog Agent configuration)
| Setting the scrape timeout to a lower value increases the risk of request timeouts which can lead to less accurate or less up-to-date metric data. | 
Metric granularity
The metrics returned by the integration endpoint provide the labels: aggregation, instance_id, and database.
An Aura instance typically runs on multiple servers to achieve availability and workload scalability in different modes. These servers are deployed across different Cloud Provider availability zones in the user-selected region.
Metrics Integration supports a more granular view of the Aura instance metrics with additional data points and labels for availability zone and instance mode combinations. This view can be enabled on demand.
See Metrics endpoint configuration for details on how to change metric granularity.
Note that there may be a delay in more granular metrics being available when a new Aura instance is created. This is because of the way 'availability zone' data is collected.
neo4j_aura_cpu_usage{aggregation="MAX",instance_id="a59d71ae",availability_zone="eu-west-1a",instance_mode="PRIMARY"} 0.025457 1724245310000
neo4j_aura_cpu_usage{aggregation="MAX",instance_id="a59d71ae",availability_zone="eu-west-1b",instance_mode="PRIMARY"} 0.047088 1724245310000
neo4j_aura_cpu_usage{aggregation="MAX",instance_id="a59d71ae",availability_zone="eu-west-1c",instance_mode="PRIMARY"} 0.021874 1724245310000- 
availability_zone- User selected Cloud provider availability zone.
- 
instance_mode-PRIMARYorSECONDARYbased on user selected workload requirement of reads and writes. (Minimum 3 primaries per instance)
Programmatic support
- 
Aura API supports fetching metrics integration endpoints using: - 
endpoint /tenants/{tenantId}/metrics-integration(for project metrics)
- 
JSON property metrics_integration_urlas part of/instances/{instanceId}response (for instance metrics)
 
- 
- 
Reference: Aura API Specification 
| Project replaces Tenant in the Aura Console UI and documentation.
However, in the API,  | 
- 
Aura CLI has a subcommand for tenantscommand to fetch project metrics endpoint:aura projects get-metrics-integration --tenant-id <YOUR_PROJECT_ID> # example output { endpoint: "https://customer-metrics-api.neo4j.io/api/v1/<YOUR_PROJECT_ID>/metrics" } # extract endpoint aura projects get-metrics-integration --project-id <YOUR_PROJECT_ID> | jq '.endpoint'
- 
For instance metrics endpoint, Aura CLI instances getcommand JSON output includes a new propertymetrics_integration_url:aura instances get --instance-id <YOUR_INSTANCE_ID> # example output { "id": "id", "name": "Production", "status": "running", "tenant_id": "YOUR_PROJECT_ID", "cloud_provider": "gcp", "connection_url": "YOUR_CONNECTION_URL", "metrics_integration_url": "https://customer-metrics-api.neo4j.io/api/v1/<YOUR_PROJECT_ID>/<YOUR_INSTANCE_ID>/metrics", "region": "europe-west1", "type": "enterprise-db", "memory": "8GB", "storage": "16GB" } # extract endpoint aura instances get --instance-id <YOUR_INSTANCE_ID> | jq '.metrics_integration_url'
- 
Reference: Aura CLI cheatsheet