Internal telemetry
You can inspect the health of any OpenTelemetry Collector instance by checking its own internal telemetry. Read on to learn about this telemetry and how to configure it to help you monitor and troubleshoot the Collector.
Activate internal telemetry in the Collector
By default, the Collector exposes its own telemetry in two ways:
- Internal metrics are exposed using a Prometheus
interface which defaults to port
8888
. - Logs are emitted to
stderr
by default.
Configure internal metrics
You can configure how internal metrics are generated and exposed by the
Collector. By default, the Collector generates basic metrics about itself and
exposes them using the OpenTelemetry Go
Prometheus exporter
for scraping at http://127.0.0.1:8888/metrics
. You can expose the endpoint to
one specific or all network interfaces when needed. For containerized
environments, you might want to expose this port on a public interface.
Set the Prometheus config under service::telemetry::metrics
:
service:
telemetry:
metrics:
readers:
- pull:
exporter:
prometheus:
host: '0.0.0.0'
port: 8888
You can adjust the verbosity of the Collector metrics output by setting the
level
field to one of the following values:
none
: no telemetry is collected.basic
: essential service telemetry.normal
: the default level, adds standard indicators on top of basic.detailed
: the most verbose level, includes dimensions and views.
Each verbosity level represents a threshold at which certain metrics are emitted. For the complete list of metrics, with a breakdown by level, see Lists of internal metrics.
The default level for metrics output is normal
. To use another level, set
service::telemetry::metrics::level
:
service:
telemetry:
metrics:
level: detailed
Configure internal logs
Log output is found in stderr
. You can configure logs in the config
service::telemetry::logs
. The
configuration options
are:
Field name | Default value | Description |
---|---|---|
level | INFO | Sets the minimum enabled logging level. Other possible values are DEBUG , WARN , and ERROR . |
development | false | Puts the logger in development mode. |
encoding | console | Sets the logger’s encoding. The other possible value is json . |
disable_caller | false | Stops annotating logs with the calling function’s file name and line number. By default, all logs are annotated. |
disable_stacktrace | false | Disables automatic stacktrace capturing. Stacktraces are captured for logs at WARN level and above in development and at ERROR level and above in production. |
sampling::enabled | true | Sets a sampling policy. |
sampling::tick | 10s | The interval in seconds that the logger applies to each sampling. |
sampling::initial | 10 | The number of messages logged at the start of each sampling::tick . |
sampling::thereafter | 100 | Sets the sampling policy for subsequent messages after sampling::initial messages are logged. When sampling::thereafter is set to N , every Nth message is logged and all others are dropped. If N is zero, the logger drops all messages after sampling::initial messages are logged. |
output_paths | ["stderr"] | A list of URLs or file paths to write logging output to. |
error_output_paths | ["stderr"] | A list of URLs or file paths to write logger errors to. |
initial_fields | A collection of static key-value pairs added to all log entries to enrich logging context. By default, there is no initial field. |
You can also see logs for the Collector on a Linux systemd system using
journalctl
:
journalctl | grep otelcol
journalctl | grep otelcol | grep Error
Configure internal traces
The Collector does not expose traces by default, but it can be configured to.
Caution
Internal tracing is an experimental feature, and no guarantees are made as to the stability of the emitted span names and attributes.The following configuration can be used to emit internal traces from the Collector to an OTLP/gRPC backend:
service:
telemetry:
traces:
processors:
- batch:
exporter:
otlp:
protocol: grpc/protobuf
endpoint: https://backend:4317
See the example configuration for additional options.
Note that the tracer_provider
section there corresponds to traces
here.
Self-monitoring
The Collector can be configured to push its own telemetry to an
OTLP receiver
and send the data through configured pipelines. In the following example, the
Collector is configured to push metrics and traces every 10s using OTLP gRPC to
localhost:14317
:
receivers:
otlp/internal:
protocols:
grpc:
endpoint: localhost:14317
exporters:
debug:
service:
pipelines:
metrics:
receivers: [otlp/internal]
exporters: [debug]
traces:
receivers: [otlp/internal]
exporters: [debug]
telemetry:
metrics:
readers:
- periodic:
interval: 10000
exporter:
otlp:
protocol: grpc/protobuf
endpoint: localhost:14317
traces:
processors:
batch:
exporter:
otlp:
protocol: grpc/protobuf
endpoint: localhost:14317
Caution
When self-monitoring, the Collector collects its own telemetry and sends it to the desired backend for analysis. This can be a risky practice. If the Collector is underperforming, its self-monitoring capability could be impacted. As a result, the self-monitored telemetry might not reach the backend in time for critical analysis.
Moreover, sending internal telemetry through the Collector’s own pipelines can create a continuous loop of spans, metric points, or logs, putting undue strain on the Collector’s performance. This setup should not be used in production.
Types of internal telemetry
The OpenTelemetry Collector aims to be a model of observable service by clearly exposing its own operational metrics. Additionally, it collects host resource metrics that can help you understand if problems are caused by a different process on the same host. Specific components of the Collector can also emit their own custom telemetry. In this section, you will learn about the different types of observability emitted by the Collector itself.
Summary of values observable with internal metrics
The Collector emits internal metrics for at least the following values:
- Process uptime and CPU time since start.
- Process memory and heap usage.
- For receivers: Items accepted and refused, per data type.
- For processors: Incoming and outgoing items.
- For exporters: Items the exporter sent, failed to enqueue, and failed to send, per data type.
- For exporters: Queue size and capacity.
- Count, duration, and size of HTTP/gRPC requests and responses.
A more detailed list is available in the following sections.
Lists of internal metrics
The following tables group each internal metric by level of verbosity: basic
,
normal
, and detailed
. Each metric is identified by name and description and
categorized by instrumentation type.
Note
As of Collector v0.106.1, internal metric names are handled differently based on their source:
- Metrics generated from Collector components are prefixed with
otelcol_
. - Metrics generated from instrumentation libraries do not use the
otelcol_
prefix by default, unless their metric names are explicitly prefixed.
For Collector versions prior to v0.106.1, all internal metrics emitted using the
Prometheus exporter, regardless of their origin, are prefixed with otelcol_
.
This includes metrics from both Collector components and instrumentation
libraries.
basic
-level metrics
Metric name | Description | Type |
---|---|---|
otelcol_exporter_enqueue_failed_ log_records | Number of logs that exporter(s) failed to enqueue. | Counter |
otelcol_exporter_enqueue_failed_ metric_points | Number of metric points that exporter(s) failed to enqueue. | Counter |
otelcol_exporter_enqueue_failed_ spans | Number of spans that exporter(s) failed to enqueue. | Counter |
otelcol_exporter_queue_capacity | Fixed capacity of the sending queue, in batches. | Gauge |
otelcol_exporter_queue_size | Current size of the sending queue, in batches. | Gauge |
otelcol_exporter_send_failed_ log_records | Number of logs that exporter(s) failed to send to destination. | Counter |
otelcol_exporter_send_failed_ metric_points | Number of metric points that exporter(s) failed to send to destination. | Counter |
otelcol_exporter_send_failed_ spans | Number of spans that exporter(s) failed to send to destination. | Counter |
otelcol_exporter_sent_log_records | Number of logs successfully sent to destination. | Counter |
otelcol_exporter_sent_metric_points | Number of metric points successfully sent to destination. | Counter |
otelcol_exporter_sent_spans | Number of spans successfully sent to destination. | Counter |
otelcol_process_cpu_seconds | Total CPU user and system time in seconds. | Counter |
otelcol_process_memory_rss | Total physical memory (resident set size) in bytes. | Gauge |
otelcol_process_runtime_heap_ alloc_bytes | Bytes of allocated heap objects (see ‘go doc runtime.MemStats.HeapAlloc’). | Gauge |
otelcol_process_runtime_total_ alloc_bytes | Cumulative bytes allocated for heap objects (see ‘go doc runtime.MemStats.TotalAlloc’). | Counter |
otelcol_process_runtime_total_ sys_memory_bytes | Total bytes of memory obtained from the OS (see ‘go doc runtime.MemStats.Sys’). | Gauge |
otelcol_process_uptime | Uptime of the process in seconds. | Counter |
otelcol_processor_batch_batch_ send_size | Number of units in the batch that was sent. | Histogram |
otelcol_processor_batch_batch_size_ trigger_send | Number of times the batch was sent due to a size trigger. | Counter |
otelcol_processor_batch_metadata_ cardinality | Number of distinct metadata value combinations being processed. | Counter |
otelcol_processor_batch_timeout_ trigger_send | Number of times the batch was sent due to a timeout trigger. | Counter |
otelcol_processor_incoming_items | Number of items passed to the processor. | Counter |
otelcol_processor_outgoing_items | Number of items emitted from the processor. | Counter |
otelcol_receiver_accepted_ log_records | Number of logs successfully ingested and pushed into the pipeline. | Counter |
otelcol_receiver_accepted_ metric_points | Number of metric points successfully ingested and pushed into the pipeline. | Counter |
otelcol_receiver_accepted_spans | Number of spans successfully ingested and pushed into the pipeline. | Counter |
otelcol_receiver_refused_ log_records | Number of logs that could not be pushed into the pipeline. | Counter |
otelcol_receiver_refused_ metric_points | Number of metric points that could not be pushed into the pipeline. | Counter |
otelcol_receiver_refused_spans | Number of spans that could not be pushed into the pipeline. | Counter |
otelcol_scraper_errored_ metric_points | Number of metric points the Collector failed to scrape. | Counter |
otelcol_scraper_scraped_ metric_points | Number of metric points scraped by the Collector. | Counter |
Additional normal
-level metrics
There are currently no metrics specific to normal
verbosity.
Additional detailed
-level metrics
Metric name | Description | Type |
---|---|---|
http_client_active_requests | Number of active HTTP client requests. | Counter |
http_client_connection_duration | Measures the duration of the successfully established outbound HTTP connections. | Histogram |
http_client_open_connections | Number of outbound HTTP connections that are active or idle on the client. | Counter |
http_client_request_size | Measures the size of HTTP client request bodies. | Counter |
http_client_duration | Measures the duration of HTTP client requests. | Histogram |
http_client_response_size | Measures the size of HTTP client response bodies. | Counter |
http_server_active_requests | Number of active HTTP server requests. | Counter |
http_server_request_size | Measures the size of HTTP server request bodies. | Counter |
http_server_duration | Measures the duration of HTTP server requests. | Histogram |
http_server_response_size | Measures the size of HTTP server response bodies. | Counter |
otelcol_processor_batch_batch_ send_size_bytes | Number of bytes in the batch that was sent. | Histogram |
rpc_client_duration | Measures the duration of outbound RPC. | Histogram |
rpc_client_request_size | Measures the size of RPC request messages (uncompressed). | Histogram |
rpc_client_requests_per_rpc | Measures the number of messages received per RPC. Should be 1 for all non-streaming RPCs. | Histogram |
rpc_client_response_size | Measures the size of RPC response messages (uncompressed). | Histogram |
rpc_client_responses_per_rpc | Measures the number of messages sent per RPC. Should be 1 for all non-streaming RPCs. | Histogram |
rpc_server_duration | Measures the duration of inbound RPC. | Histogram |
rpc_server_request_size | Measures the size of RPC request messages (uncompressed). | Histogram |
rpc_server_requests_per_rpc | Measures the number of messages received per RPC. Should be 1 for all non-streaming RPCs. | Histogram |
rpc_server_response_size | Measures the size of RPC response messages (uncompressed). | Histogram |
rpc_server_responses_per_rpc | Measures the number of messages sent per RPC. Should be 1 for all non-streaming RPCs. | Histogram |
Note
The http_
and rpc_
metrics come from
instrumentation libraries. Their original names use dots (.
), but when
exposing internal metrics with Prometheus, they are translated to use
underscores (_
) to match Prometheus’ naming constraints.
The otelcol_processor_batch_
metrics are unique to the batchprocessor
.
The otelcol_receiver_
, otelcol_scraper_
, otelcol_processor_
, and
otelcol_exporter_
metrics come from their respective helper
packages. As
such, some components not using those packages may not emit them.
Events observable with internal logs
The Collector logs the following internal events:
- A Collector instance starts or stops.
- Data dropping begins due to throttling for a specified reason, such as local saturation, downstream saturation, downstream unavailable, etc.
- Data dropping due to throttling stops.
- Data dropping begins due to invalid data. A sample of the invalid data is included.
- Data dropping due to invalid data stops.
- A crash is detected, differentiated from a clean stop. Crash data is included if available.
Telemetry maturity levels
Traces
Tracing instrumentation is still under active development, and changes might be made to span names, attached attributes, instrumented endpoints, or other aspects of the telemetry. Until this feature graduates to stable, there are no guarantees of backwards compatibility for tracing instrumentation.
Metrics
The Collector’s metrics follow a four-stage lifecycle:
Alpha metric → Stable metric → Deprecated metric → Deleted metric
Alpha
Alpha metrics have no stability guarantees. These metrics can be modified or deleted at any time.
Stable
Stable metrics are guaranteed to not change. This means:
- A stable metric without a deprecated signature will not be deleted or renamed.
- A stable metric’s type and attributes will not be modified.
Deprecated
Deprecated metrics are slated for deletion but are still available for use. The description of these metrics include an annotation about the version in which they became deprecated. For example:
Before deprecation:
# HELP otelcol_exporter_queue_size this counts things
# TYPE otelcol_exporter_queue_size counter
otelcol_exporter_queue_size 0
After deprecation:
# HELP otelcol_exporter_queue_size (Deprecated since 1.15.0) this counts things
# TYPE otelcol_exporter_queue_size counter
otelcol_exporter_queue_size 0
Deleted
Deleted metrics are no longer published and cannot be used.
Logs
Individual log entries and their formatting might change from one release to the next. There are no stability guarantees at this time.
Use internal telemetry to monitor the Collector
This section recommends best practices for monitoring the Collector using its own telemetry.
Critical monitoring
Data loss
Use the rate of otelcol_processor_dropped_log_records > 0
,
otelcol_processor_dropped_spans > 0
, and
otelcol_processor_dropped_metric_points > 0
to detect data loss. Depending on
your project’s requirements, select a narrow time window before alerting begins
to avoid notifications for small losses that are within the desired reliability
range and not considered outages.
Secondary monitoring
Queue length
Most exporters provide a queue and/or retry mechanism that is recommended for use in any production deployment of the Collector.
The otelcol_exporter_queue_capacity
metric indicates the capacity, in batches,
of the sending queue. The otelcol_exporter_queue_size
metric indicates the
current size of the sending queue. Use these two metrics to check if the queue
capacity can support your workload.
Using the following three metrics, you can identify the number of spans, metric points, and log records that failed to reach the sending queue:
otelcol_exporter_enqueue_failed_spans
otelcol_exporter_enqueue_failed_metric_points
otelcol_exporter_enqueue_failed_log_records
These failures could be caused by a queue filled with unsettled elements. You might need to decrease your sending rate or horizontally scale Collectors.
The queue or retry mechanism also supports logging for monitoring. Check the
logs for messages such as Dropping data because sending_queue is full
.
Receive failures
Sustained rates of otelcol_receiver_refused_log_records
,
otelcol_receiver_refused_spans
, and otelcol_receiver_refused_metric_points
indicate that too many errors were returned to clients. Depending on the
deployment and the clients’ resilience, this might indicate clients’ data loss.
Sustained rates of otelcol_exporter_send_failed_log_records
,
otelcol_exporter_send_failed_spans
, and
otelcol_exporter_send_failed_metric_points
indicate that the Collector is not
able to export data as expected. These metrics do not inherently imply data loss
since there could be retries. But a high rate of failures could indicate issues
with the network or backend receiving the data.
Data flow
You can monitor data ingress with the otelcol_receiver_accepted_log_records
,
otelcol_receiver_accepted_spans
, and otelcol_receiver_accepted_metric_points
metrics and data egress with the otelcol_exporter_sent_log_records
,
otelcol_exporter_sent_spans
, and otelcol_exporter_sent_metric_points
metrics.
[i18n] feedback_title
[i18n] feedback_question
Thank you. Your feedback is appreciated!
Please let us know how we can improve this page. Your feedback is appreciated!