src/go/plugin/go.d/collector/couchbase/README.md
Plugin: go.d.plugin Module: couchbase
This collector monitors Couchbase servers.
This collector is supported on all platforms.
This collector supports collecting metrics from multiple instances of this integration, including remote instances.
This integration doesn't support auto-detection.
The default configuration for this integration does not impose any limits on data collection.
The default configuration for this integration is not expected to impose a significant performance impact on the system.
You can configure the couchbase collector in two ways:
| Method | Best for | How to |
|---|---|---|
| UI | Fast setup without editing files | Go to Nodes → Configure this node → Collectors → Jobs, search for couchbase, then click + to add a job. |
| File | If you prefer configuring via file, or need to automate deployments (e.g., with Ansible) | Edit go.d/couchbase.conf and add a job. |
:::important
UI configuration requires paid Netdata Cloud plan.
:::
No action required.
The following options can be defined globally: update_every, autodetection_retry.
<details open><summary>All options</summary>| Group | Option | Description | Default | Required |
|---|---|---|---|---|
| Collection | update_every | Data collection interval (seconds). | 5 | no |
| autodetection_retry | Autodetection retry interval (seconds). Set 0 to disable. | 0 | no | |
| Target | url | Target endpoint URL. | http://127.0.0.1:8091 | yes |
| timeout | HTTP request timeout (seconds). | 1 | no | |
| HTTP Auth | username | Username for Basic HTTP authentication. | no | |
| password | Password for Basic HTTP authentication. | no | ||
| bearer_token_file | Path to a file containing a bearer token (used for Authorization: Bearer). | no | ||
| TLS | tls_skip_verify | Skip TLS certificate and hostname verification (insecure). | no | no |
| tls_ca | Path to CA bundle used to validate the server certificate. | no | ||
| tls_cert | Path to client TLS certificate (for mTLS). | no | ||
| tls_key | Path to client TLS private key (for mTLS). | no | ||
| Proxy | proxy_url | HTTP proxy URL. | no | |
| proxy_username | Username for proxy Basic HTTP authentication. | no | ||
| proxy_password | Password for proxy Basic HTTP authentication. | no | ||
| Request | method | HTTP method to use. | GET | no |
| body | Request body (e.g., for POST/PUT). | no | ||
| headers | Additional HTTP headers (one per line as key: value). | no | ||
| not_follow_redirects | Do not follow HTTP redirects. | no | no | |
| force_http2 | Force HTTP/2 (including h2c over TCP). | no | no | |
| Functions | functions.top_queries.disabled | Disable the top-queries function. | no | no |
| functions.top_queries.timeout | Query timeout (seconds). Uses collector timeout if not set. | no | ||
| functions.top_queries.limit | Maximum number of queries to return. | 500 | no | |
| Virtual Node | vnode | Associates this data collection job with a Virtual Node. | no |
Configure the couchbase collector from the Netdata web interface:
The configuration file name for this integration is go.d/couchbase.conf.
The file format is YAML. Generally, the structure is:
update_every: 1
autodetection_retry: 0
jobs:
- name: some_name1
- name: some_name2
You can edit the configuration file using the edit-config script from the
Netdata config directory.
cd /etc/netdata 2>/dev/null || cd /opt/netdata/etc/netdata
sudo ./edit-config go.d/couchbase.conf
An example configuration.
<details open><summary>Config</summary>jobs:
- name: local
url: http://127.0.0.1:8091
Local server with basic HTTP authentication.
<details open><summary>Config</summary>jobs:
- name: local
url: http://127.0.0.1:8091
username: foo
password: bar
Note: When you define multiple jobs, their names must be unique.
Collecting metrics from local and remote instances.
<details open><summary>Config</summary>jobs:
- name: local
url: http://127.0.0.1:8091
- name: remote
url: http://203.0.113.0:8091
There are no alerts configured by default for this integration.
Metrics grouped by scope.
The scope defines the instance that the metric belongs to. An instance is uniquely identified by a set of labels.
These metrics refer to the entire monitored application.
This scope has no labels.
Metrics:
| Metric | Dimensions | Unit |
|---|---|---|
| couchbase.bucket_quota_percent_used | a dimension per bucket | percentage |
| couchbase.bucket_ops_per_sec | a dimension per bucket | ops/s |
| couchbase.bucket_disk_fetches | a dimension per bucket | fetches |
| couchbase.bucket_item_count | a dimension per bucket | items |
| couchbase.bucket_disk_used_stats | a dimension per bucket | bytes |
| couchbase.bucket_data_used | a dimension per bucket | bytes |
| couchbase.bucket_mem_used | a dimension per bucket | bytes |
| couchbase.bucket_vb_active_num_non_resident | a dimension per bucket | items |
This collector exposes real-time functions for interactive troubleshooting in the Live tab.
Retrieves completed N1QL query statistics from Couchbase system:completed_requests keyspace.
This function queries the system:completed_requests keyspace which stores information about recently completed N1QL requests. It provides timing metrics, result statistics, and error/warning counts for each completed query.
Use cases:
Statement text is truncated at 4096 characters for display purposes.
| Aspect | Description |
|---|---|
| Name | Couchbase:top-queries |
| Require Cloud | yes |
| Performance | Queries system:completed_requests via the N1QL query service: |
• The completed_requests keyspace has a configurable size limit (completed-limit setting) | |
| • Default limit of 500 rows balances usefulness with performance | |
| Security | Query text may contain unmasked literal values including potentially sensitive data: |
| • Personal information in WHERE clauses or INSERT values | |
| • Business data embedded in queries | |
| • Access should be restricted to authorized personnel only | |
| Availability | Available when: |
| • The collector has successfully connected to Couchbase | |
| • The N1QL (Query) service is running | |
| • Returns HTTP 503 if collector is still initializing | |
| • Returns HTTP 500 if the query fails | |
| • Returns HTTP 504 if the query times out |
system:completed_requestsThe user must have appropriate privileges to query system keyspaces and the N1QL service must be available.
Ensure the N1QL (Query) service is running on the cluster
Grant query system catalog privileges to the monitoring user:
GRANT QUERY_SYSTEM_CATALOG TO netdata_user;
Verify access to completed_requests:
SELECT * FROM system:completed_requests LIMIT 1;
:::info
system:completed_requests keyspace stores recently completed queries based on Couchbase server settings completed-limit and completed-thresholdcompleted-threshold (default 1000ms) are logged to completed_requestscompleted-threshold in Couchbase Query Settings to capture faster queries if needed:::
| Parameter | Type | Description | Required | Default | Options |
|---|---|---|---|---|---|
| Filter By | select | Select the primary sort column. Options include elapsed time, service time, request time, and result count. Defaults to elapsed time to focus on slowest queries. | yes | elapsedTime |
Completed N1QL request statistics. Each row represents a single completed query with its timing and result metrics.
| Column | Type | Unit | Visibility | Description |
|---|---|---|---|---|
| Request ID | string | hidden | Unique identifier for the N1QL request. Can be used for correlation with Couchbase logs. | |
| Request Time | timestamp | Timestamp when the request was received by the query service. | ||
| Statement | string | The N1QL statement that was executed. Truncated to 4096 characters. | ||
| Elapsed Time | duration | milliseconds | Total time from request receipt to response completion, including queue time, planning, execution, and result streaming. | |
| Service Time | duration | milliseconds | Time spent actively processing the request, excluding network latency and queue wait time. Compare with elapsed time to identify network or queueing delays. | |
| Result Count | integer | Number of documents/rows returned by the query. High values may indicate queries returning excessive data. | ||
| Result Size | integer | hidden | Total size of the result set in bytes. Large result sizes may indicate inefficient queries or missing projections. | |
| Error Count | integer | hidden | Number of errors encountered during query execution. Non-zero values require investigation. | |
| Warning Count | integer | hidden | Number of warnings generated during query execution. Warnings may indicate suboptimal query patterns or index usage. | |
| User | string | Couchbase user who executed the query. Useful for identifying workload by user or application. | ||
| Client Context ID | string | hidden | Client-provided context identifier for request tracking and correlation. |
Important: Debug mode is not supported for data collection jobs created via the UI using the Dyncfg feature.
To troubleshoot issues with the couchbase collector, run the go.d.plugin with the debug option enabled. The output
should give you clues as to why the collector isn't working.
Navigate to the plugins.d directory, usually at /usr/libexec/netdata/plugins.d/. If that's not the case on
your system, open netdata.conf and look for the plugins setting under [directories].
cd /usr/libexec/netdata/plugins.d/
Switch to the netdata user.
sudo -u netdata -s
Run the go.d.plugin to debug the collector:
./go.d.plugin -d -m couchbase
To debug a specific job:
./go.d.plugin -d -m couchbase -j jobName
If you're encountering problems with the couchbase collector, follow these steps to retrieve logs and identify potential issues:
Use the following command to view logs generated since the last Netdata service restart:
journalctl _SYSTEMD_INVOCATION_ID="$(systemctl show --value --property=InvocationID netdata)" --namespace=netdata --grep couchbase
Locate the collector log file, typically at /var/log/netdata/collector.log, and use grep to filter for collector's name:
grep couchbase /var/log/netdata/collector.log
Note: This method shows logs from all restarts. Focus on the latest entries for troubleshooting current issues.
If your Netdata runs in a Docker container named "netdata" (replace if different), use this command:
docker logs netdata 2>&1 | grep couchbase