Opensearch Exporter
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 templatess4o_{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 logslogs_index_fallback- Fallback value when placeholder is missing (default:unknown)logs_index_time_format- Time suffix format for logstraces_index- Custom index name pattern for tracestraces_index_fallback- Fallback value when placeholder is missing (default:unknown)traces_index_time_format- Time suffix format for traces
- Placeholder:
%{key}- Example:
otel-logs-%{service.name}orotel-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
- Example:
*_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
- Logs:
ss4o_logs-{dataset}-{namespace} - Traces:
ss4o_traces-{dataset}-{namespace}
Example Configuration
- Log indexes like:
otel-logs-myservice-prod-2024.06.07 - Trace indexes like:
otel-traces-myservice-production-2024.06.07
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 attributeopensearch.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 Schemaflatten_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 defaultSimple 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
Inbodymap 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
retry_on_failure: See retry_on_failure
Sending Queue Options
sending_queue: See sending_queue
Timeout Options
timeout: See timeout
Bulk Indexer Options
bulk_action(optional): the action for ingesting data. Onlycreateandindexare allowed here.
Example
Configuration
Example Configuration
Last generated: 2026-04-13