Documentation Index
Fetch the complete documentation index at: https://otel.fyi/llms.txt
Use this file to discover all available pages before exploring further.
Opensearch Exporter
Available in: contrib
Maintainers: @ps48
Source: opentelemetry-collector-contrib
Supported Telemetry
Overview
OpenSearch exporter supports sending OpenTelemetry signals as documents to OpenSearch.
The documents are sent using observability catalog schema.
Configuration options
Indexing Options
The Observability indices would follow the recommended pattern for immutable data stream ingestion using
the data_stream concepts.
Index pattern will follow the next naming template ss4o_{type}-{dataset}-{namespace}
dataset (default=default) a user-provided label to classify source of telemetry. It is used to construct the name of the destination index or data stream.
namespace (default=namespace) a user-provided label to group telemetry. It is used to construct the name of the destination index or data stream.
Dynamic Indexing
The OpenSearch exporter supports dynamic index names for both logs and traces using placeholders. You can use any attribute or context key as a placeholder to construct index names dynamically per record.
Caution: In practice, OpenSearch clusters can become unstable or even break down when index counts reach a very high level. Introducing attributes with high cardinality resulting in many separate indices can significantly impact the stability of your target cluster.
Configuration Options:
logs_index - Custom index name pattern for logs
logs_index_fallback - Fallback value when placeholder is missing (default: unknown)
logs_index_time_format - Time suffix format for logs
traces_index - Custom index name pattern for traces
traces_index_fallback - Fallback value when placeholder is missing (default: unknown)
traces_index_time_format - Time suffix format for traces
Placeholder Syntax:
- Placeholder:
%{key}
- Example:
otel-logs-%{service.name} or otel-traces-%{service.name}-%{env}
- Multiple placeholders are supported per index name
- The value is looked up from item attributes (log/span), scope attributes, and resource attributes (in that precedence order)
- If the key is missing, the fallback value is used
- Generated index names must adhere to OpenSearch index naming restrictions
Time Suffix Format:
Both logs and traces support time-formatted suffixes using *_time_format options. The time suffix only supports UTC.
- Valid tokens (case-sensitive):
yyyy (4-digit year), yy (2-digit year)
MM (2-digit month), dd (2-digit day)
HH (2-digit hour, 24h), mm (2-digit minute), ss (2-digit second)
- Allowed separators:
-, ., _, +
- Examples:
yyyy.MM.dd → 2024.06.07, yyyy-MM → 2024-06, yyMMdd → 240607
Default Behavior:
If custom index names are not set, the exporter uses default patterns:
- Logs:
ss4o_logs-{dataset}-{namespace}
- Traces:
ss4o_traces-{dataset}-{namespace}
Example Configuration
exporters:
opensearch:
http:
endpoint: http://opensearch.example.com:9200
# Logs configuration
logs_index: "otel-logs-%{service.name}-%{env}"
logs_index_fallback: "default"
logs_index_time_format: "yyyy.MM.dd"
# Traces configuration
traces_index: "otel-traces-%{service.name}-%{deployment.environment}"
traces_index_fallback: "unknown"
traces_index_time_format: "yyyy.MM.dd"
sending_queue:
batch:
This configuration will create:
- Log indexes like:
otel-logs-myservice-prod-2024.06.07
- Trace indexes like:
otel-traces-myservice-production-2024.06.07
If any placeholder key is missing, the fallback value is used e.g.:
otel-logs-myservice-default-2024.06.07).
otel-traces-unknown-production-2024.06.07
OpenSearch document mapping
The mapping mode can be controlled via the scope attribute opensearch.mapping.mode.
The OpenSearch exporter supports several document schemas and preprocessing behaviors, which may be configured through the following settings:
mapping:
mode (default=ss4o): Configures the field mappings. Supported modes are:
ss4o: Exports logs in the Simple Schema for Observability standard.
ecs: Maps fields defined in the OpenTelemetry Semantic Conventions to the Elastic Common Schema
flatten_attributes: Uses the ECS mapping but flattens all resource and log attributes in the record to the top-level.
bodymap: uses the “body” of a log record as the exact content of the OpenSearch document, without any transformation. This mapping mode is intended for use cases where the client wishes to have complete control over the OpenSearch document structure.
timestamp_field: (optional) Field to store the timestamp in. If not set, uses the default @timestamp.
unix_timestamp: (optional) Whether to store the timestamp in epoch milliseconds.
dedup: (optional) removes fields from the document, that have duplicate keys. The filtering only keeps the last value for a key.
dedot: (optional) convert dotted keys into nested JSON objects.
SS4O mapping mode
The default Simple Schema for Observability mapping mode.
In ss4o mapping mode, the OpenSearch exporter stores documents using the SS4O schema, which is designed for observability data in OpenSearch. Documents use standardized field names and structure to facilitate integration with OpenSearch dashboards and tools.
| Signal | Supported |
|---|
| Logs | :white_check_mark: |
| Traces | :white_check_mark: |
ECS mapping mode
[!WARNING]
The ECS mapping mode is currently undergoing changes, and its behaviour is unstable.
In ecs mapping mode, the OpenSearch exporter maps fields from OpenTelemetry Semantic Conventions to Elastic Common Schema (ECS) where possible. This mode may be used for compatibility with dashboards and tools that expect ECS.
| Signal | ecs |
|---|
| Logs | :white_check_mark: |
| Traces | :no_entry_sign: |
Flatten attributes mapping mode
[!WARNING]
The Flatten attributes mapping mode is currently undergoing changes, and its behaviour is unstable.
In flatten_attributes mapping mode, the OpenSearch exporter uses the ECS mapping but flattens all resource and log attributes in the record to the top-level of the document.
| Signal | flatten_attributes |
|---|
| Logs | :white_check_mark: |
| Traces | :no_entry_sign: |
Bodymap mapping mode
In bodymap mapping mode, the OpenSearch exporter supports only logs and uses the “body” of a log record as the exact content of the OpenSearch document, without any transformation. This mapping mode is intended for use cases where the client wishes to have complete control over the OpenSearch document structure.
The bodymap mapping mode only supports log records where the body is of type Map. If the log body is not a Map, encoding will fail with an error. This ensures that only structured map data can be used as the document content in bodymap mode.
| Signal | bodymap |
|---|
| Logs | :white_check_mark: |
| Traces | :no_entry_sign: |
HTTP Connection Options
OpenSearch export supports standard HTTP client settings.
http.endpoint (required) <url>:<port> of OpenSearch node to send data to.
TLS settings
Supports standard TLS settings as part of HTTP settings. See TLS Configuration/Client Settings.
Retry Options
Sending Queue Options
Timeout Options
Bulk Indexer Options
bulk_action (optional): the action for ingesting data. Only create and index are allowed here.
Example
extensions:
basicauth/client:
client_auth:
username: username
password: password
exporters:
opensearch/trace:
http:
endpoint: https://opensearch.example.com:9200
auth:
authenticator: basicauth/client
sending_queue:
batch:
service:
pipelines:
traces:
receivers: [otlp]
exporters: [opensearch/trace]
Configuration
Example Configuration
extensions:
basicauth/sample_basic_auth:
username: test
password: testtoo
opensearch:
http:
endpoint: https://opensearch.example.com:9200
opensearch/default:
opensearch/empty_namespace:
dataset: ngnix
namespace: ""
http:
endpoint: https://opensearch.example.com:9200
opensearch/empty_dataset:
dataset: ""
namespace: eu
http:
endpoint: https://opensearch.example.com:9200
opensearch/invalid_bulk_action:
bulk_action: "delete"
http:
endpoint: https://opensearch.example.com:9200
opensearch/trace:
dataset: ngnix
namespace: eu
http:
tls:
insecure: false
endpoint: https://opensearch.example.com:9200
timeout: 2m
headers:
myheader: test
auth:
authenticator: sample_basic_auth
timeout:
retry_on_failure:
enabled: true
initial_interval: 100000000
randomization_factor: 0.5
opensearch/dynamic_log_indexing:
http:
endpoint: https://opensearch.example.com:9200
logs_index: "otel-logs-%{service.name}"
logs_index_fallback: "default-service"
logs_index_time_format: "yyyy.MM.dd"
opensearch/log_index_time_format_valid:
http:
endpoint: https://opensearch.example.com:9200
logs_index: "otel-logs-%{service.name}"
logs_index_fallback: "default-service"
logs_index_time_format: "yyyy.MM.dd"
opensearch/log_index_time_format_empty:
http:
endpoint: https://opensearch.example.com:9200
logs_index: "otel-logs-%{service.name}"
logs_index_fallback: "default-service"
logs_index_time_format: ""
opensearch/log_index_time_format_invalid:
http:
endpoint: https://opensearch.example.com:9200
logs_index: "otel-logs-%{service.name}"
logs_index_fallback: "default-service"
logs_index_time_format: "invalid_format!"
opensearch/log_index_time_format_whitespace:
http:
endpoint: https://opensearch.example.com:9200
logs_index: "otel-logs-%{service.name}"
logs_index_fallback: "default-service"
logs_index_time_format: " "
opensearch/log_index_time_format_special_chars:
http:
endpoint: https://opensearch.example.com:9200
logs_index: "otel-logs-%{service.name}"
logs_index_fallback: "default-service"
logs_index_time_format: "yyyy/MM/dd@!#"
opensearch/traces_index_valid:
http:
endpoint: https://opensearch.example.com:9200
traces_index: "otel-traces-%{service.name}"
traces_index_fallback: "default-service"
traces_index_time_format: "yyyy.MM.dd"
opensearch/traces_index_time_format_valid:
http:
endpoint: https://opensearch.example.com:9200
traces_index: "otel-traces-%{service.name}"
traces_index_fallback: "default-service"
traces_index_time_format: "yyyy.MM.dd"
opensearch/traces_index_time_format_empty:
http:
endpoint: https://opensearch.example.com:9200
traces_index: "otel-traces-%{service.name}"
traces_index_fallback: "default-service"
traces_index_time_format: ""
opensearch/traces_index_time_format_invalid:
http:
endpoint: https://opensearch.example.com:9200
traces_index: "otel-traces-%{service.name}"
traces_index_fallback: "default-service"
traces_index_time_format: "invalid_format!"
opensearch/sending_queue_with_batch:
http:
endpoint: https://opensearch.example.com:9200
logs_index: otel-logs
logs_index_time_format: "yyyy-MM-dd"
sending_queue:
batch:
Last generated: 2026-04-20