From 2859b176d9cb64a66d4106a69c7fded5542a5221 Mon Sep 17 00:00:00 2001 From: Jack Berg Date: Wed, 11 Dec 2024 17:15:08 -0600 Subject: [PATCH 1/6] Add type information for environment variables --- .../sdk-environment-variables.md | 173 ++++++++++-------- specification/metrics/sdk_exporters/otlp.md | 8 +- specification/protocol/exporter.md | 10 + 3 files changed, 113 insertions(+), 78 deletions(-) diff --git a/specification/configuration/sdk-environment-variables.md b/specification/configuration/sdk-environment-variables.md index c7d8ee4cad3..35cac76b047 100644 --- a/specification/configuration/sdk-environment-variables.md +++ b/specification/configuration/sdk-environment-variables.md @@ -17,11 +17,14 @@ aliases: - [Implementation guidelines](#implementation-guidelines) - [Parsing empty value](#parsing-empty-value) -- [Special configuration types](#special-configuration-types) - * [Boolean value](#boolean-value) - * [Numeric value](#numeric-value) - * [Enum value](#enum-value) - * [Duration](#duration) +- [Configuration types](#configuration-types) + * [Boolean](#boolean) + * [Numeric](#numeric) + + [Float](#float) + + [Integer](#integer) + + [Duration](#duration) + * [String](#string) + + [Enum](#enum) - [General SDK Configuration](#general-sdk-configuration) - [Batch Span Processor](#batch-span-processor) - [Batch LogRecord Processor](#batch-logrecord-processor) @@ -58,9 +61,9 @@ The environment-based configuration MUST have a direct code configuration equiva The SDK MUST interpret an empty value of an environment variable the same way as when the variable is unset. -## Special configuration types +## Configuration types -### Boolean value +### Boolean Any value that represents a Boolean MUST be set to true only by the case-insensitive string `"true"`, meaning `"True"` or `"TRUE"` are also accepted, as true. An implementation MUST NOT extend this definition and define additional values that are interpreted as true. @@ -69,9 +72,15 @@ If any value other than a true value, case-insensitive string `"false"`, empty, All Boolean environment variables SHOULD be named and defined such that false is the expected safe default behavior. Renaming or changing the default value MUST NOT happen without a major version upgrade. -### Numeric value +### Numeric -If an implementation chooses to support an integer-valued environment variable, it SHOULD support nonnegative values between 0 and 2³¹ − 1 (inclusive). Individual SDKs MAY choose to support a larger range of values. +Variables accepting numeric values are sub-classified into: + +* [integer](#integer) +* [float](#float) +* [duration](#duration) + +The following guidance applies to all numeric types. > The following paragraph was added after stabilization and the requirements are > thus qualified as "SHOULD" to allow implementations to avoid breaking changes. @@ -93,14 +102,15 @@ Instead the default buffer size should be used. Note that this could make a difference even if the custom interpretation is identical with the default value, because it might reset a value set from other configuration sources with the default. -### Enum value +#### Float -For variables which accept a known value out of a set, i.e., an enum value, implementations MAY support additional values not listed here. -For variables accepting an enum value, if the user provides a value the implementation does not recognize, the implementation MUST generate a warning and gracefully ignore the setting. +If an implementation chooses to support a float-valued environment variable, it SHOULD support single precision floating point (IEEE 754-1985). Individual SDKs MAY choose to support a larger range of values. -If a null object (empty, no-op) value is acceptable, then the enum value representing it MUST be `"none"`. +#### Integer + +If an implementation chooses to support an integer-valued environment variable, it SHOULD support nonnegative values between 0 and 2³¹ − 1 (inclusive). Individual SDKs MAY choose to support a larger range of values. -### Duration +#### Duration Any value that represents a duration, for example a timeout, MUST be an integer representing a number of milliseconds. The value is non-negative - if a negative value is provided, the implementation MUST generate a warning, @@ -108,17 +118,32 @@ gracefully ignore the setting and use the default value if it is defined. For example, the value `12000` indicates 12000 milliseconds, i.e., 12 seconds. +### String + +String values are sub-classified into: + +* [enum](#enum). + +Normally, string values includes notes describing how they are interpreted by implementations. + +#### Enum + +For variables which accept a known value out of a set, i.e., an enum value, implementations MAY support additional values not listed here. +For variables accepting an enum value, if the user provides a value the implementation does not recognize, the implementation MUST generate a warning and gracefully ignore the setting. + +If a null object (empty, no-op) value is acceptable, then the enum value representing it MUST be `"none"`. + ## General SDK Configuration -| Name | Description | Default | Notes | -|--------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| OTEL_SDK_DISABLED | Disable the SDK for all signals | false | Boolean value. If "true", a no-op SDK implementation will be used for all telemetry signals. Any other value or absence of the variable will have no effect and the SDK will remain enabled. This setting has no effect on propagators configured through the OTEL_PROPAGATORS variable. | -| OTEL_RESOURCE_ATTRIBUTES | Key-value pairs to be used as resource attributes | See [Resource semantic conventions](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#semantic-attributes-with-dedicated-environment-variable) for details. | See [Resource SDK](../resource/sdk.md#specifying-resource-information-via-an-environment-variable) for more details. | -| OTEL_SERVICE_NAME | Sets the value of the [`service.name`](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#service) resource attribute | | If `service.name` is also provided in `OTEL_RESOURCE_ATTRIBUTES`, then `OTEL_SERVICE_NAME` takes precedence. | -| OTEL_LOG_LEVEL | Log level used by the [SDK internal logger](../error-handling.md#self-diagnostics) | "info" | | -| OTEL_PROPAGATORS | Propagators to be used as a comma-separated list | "tracecontext,baggage" | Values MUST be deduplicated in order to register a `Propagator` only once. | -| OTEL_TRACES_SAMPLER | Sampler to be used for traces | "parentbased_always_on" | See [Sampling](../trace/sdk.md#sampling) | -| OTEL_TRACES_SAMPLER_ARG | String value to be used as the sampler argument | | The specified value will only be used if OTEL_TRACES_SAMPLER is set. Each Sampler type defines its own expected input, if any. Invalid or unrecognized input MUST be logged and MUST be otherwise ignored, i.e. the implementation MUST behave as if OTEL_TRACES_SAMPLER_ARG is not set. | +| Name | Description | Default | [Type](#configuration-types) | Notes | +|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| +| OTEL_SDK_DISABLED | Disable the SDK for all signals | false | `boolean` | If "true", a no-op SDK implementation will be used for all telemetry signals. Any other value or absence of the variable will have no effect and the SDK will remain enabled. This setting has no effect on propagators configured through the OTEL_PROPAGATORS variable. | +| OTEL_RESOURCE_ATTRIBUTES | Key-value pairs to be used as resource attributes | See [Resource semantic conventions](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#semantic-attributes-with-dedicated-environment-variable) for details. | `string` | See [Resource SDK](../resource/sdk.md#specifying-resource-information-via-an-environment-variable) for more details. | +| OTEL_SERVICE_NAME | Sets the value of the [`service.name`](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#service) resource attribute | | `string` | If `service.name` is also provided in `OTEL_RESOURCE_ATTRIBUTES`, then `OTEL_SERVICE_NAME` takes precedence. | +| OTEL_LOG_LEVEL | Log level used by the [SDK internal logger](../error-handling.md#self-diagnostics) | "info" | `enum` | | +| OTEL_PROPAGATORS | Propagators to be used as a comma-separated list | "tracecontext,baggage" | `enum` | Values MUST be deduplicated in order to register a `Propagator` only once. | +| OTEL_TRACES_SAMPLER | Sampler to be used for traces | "parentbased_always_on" | `enum` | See [Sampling](../trace/sdk.md#sampling) | +| OTEL_TRACES_SAMPLER_ARG | String value to be used as the sampler argument | | `float` or `string` | The specified value will only be used if OTEL_TRACES_SAMPLER is set. Each Sampler type defines its own expected input, if any. Invalid or unrecognized input MUST be logged and MUST be otherwise ignored, i.e. the implementation MUST behave as if OTEL_TRACES_SAMPLER_ARG is not set. | Known values for `OTEL_PROPAGATORS` are: @@ -154,21 +179,21 @@ Depending on the value of `OTEL_TRACES_SAMPLER`, `OTEL_TRACES_SAMPLER_ARG` may b ## Batch Span Processor -| Name | Description | Default | Notes | -| ------------------------------ | ---------------------------------------------------------------- | ------- | ----------------------------------------------------- | -| OTEL_BSP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 5000 | | -| OTEL_BSP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | | -| OTEL_BSP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | | -| OTEL_BSP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | Must be less than or equal to OTEL_BSP_MAX_QUEUE_SIZE | +| Name | Description | Default | [Type](#configuration-types) | Notes | +|--------------------------------|------------------------------------------------------------------|---------|------------------------------|-------------------------------------------------------| +| OTEL_BSP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 5000 | `duration` | | +| OTEL_BSP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | `duration` | | +| OTEL_BSP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | `integer` | | +| OTEL_BSP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | `integer` | Must be less than or equal to OTEL_BSP_MAX_QUEUE_SIZE | ## Batch LogRecord Processor -| Name | Description | Default | Notes | -| ------------------------------- | ---------------------------------------------------------------- | ------- | ------------------------------------------------------ | -| OTEL_BLRP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 1000 | | -| OTEL_BLRP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | | -| OTEL_BLRP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | | -| OTEL_BLRP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | Must be less than or equal to OTEL_BLRP_MAX_QUEUE_SIZE | +| Name | Description | Default | [Type](#configuration-types) | Notes | +|---------------------------------|------------------------------------------------------------------|---------|------------------------------|--------------------------------------------------------| +| OTEL_BLRP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 1000 | `duration` | | +| OTEL_BLRP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | `duration` | | +| OTEL_BLRP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | `integer` | | +| OTEL_BLRP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | `integer` | Must be less than or equal to OTEL_BLRP_MAX_QUEUE_SIZE | ## Attribute Limits @@ -177,32 +202,32 @@ which that SDK implements truncation mechanism. See the SDK [Attribute Limits](../common/README.md#attribute-limits) section for the definition of the limits. -| Name | Description | Default | Notes | -| --------------------------------- | ------------------------------------ | ------- | ----- | -| OTEL_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit| | -| OTEL_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute count | 128 | | +| Name | Description | Default | [Type](#configuration-types) | +|-----------------------------------|--------------------------------------|----------|------------------------------| +| OTEL_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | `integer` | +| OTEL_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute count | 128 | `integer` | ## Span Limits See the SDK [Span Limits](../trace/sdk.md#span-limits) section for the definition of the limits. -| Name | Description | Default | Notes | -| -------------------------------------- | ---------------------------------------------- | ------- | ----- | -| OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | | -| OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT | Maximum allowed span attribute count | 128 | | -| OTEL_SPAN_EVENT_COUNT_LIMIT | Maximum allowed span event count | 128 | | -| OTEL_SPAN_LINK_COUNT_LIMIT | Maximum allowed span link count | 128 | | -| OTEL_EVENT_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span event count | 128 | | -| OTEL_LINK_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span link count | 128 | | +| Name | Description | Default | [Type](#configuration-types) | +|----------------------------------------|------------------------------------------------|----------|------------------------------| +| OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | `integer` | +| OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT | Maximum allowed span attribute count | 128 | `integer` | +| OTEL_SPAN_EVENT_COUNT_LIMIT | Maximum allowed span event count | 128 | `integer` | +| OTEL_SPAN_LINK_COUNT_LIMIT | Maximum allowed span link count | 128 | `integer` | +| OTEL_EVENT_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span event count | 128 | `integer` | +| OTEL_LINK_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span link count | 128 | `integer` | ## LogRecord Limits See the SDK [LogRecord Limits](../logs/sdk.md#logrecord-limits) section for the definition of the limits. -| Name | Description | Default | Notes | -| ------------------------------------------- | -------------------------------------------| -------- | ----- | -| OTEL_LOGRECORD_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | | -| OTEL_LOGRECORD_ATTRIBUTE_COUNT_LIMIT | Maximum allowed log record attribute count | 128 | | +| Name | Description | Default | [Type](#configuration-types) | +|---------------------------------------------|--------------------------------------------|----------|------------------------------| +| OTEL_LOGRECORD_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | `integer` | +| OTEL_LOGRECORD_ATTRIBUTE_COUNT_LIMIT | Maximum allowed log record attribute count | 128 | `integer` | ## OTLP Exporter @@ -210,10 +235,10 @@ See [OpenTelemetry Protocol Exporter Configuration Options](../protocol/exporter ## Zipkin Exporter -| Name | Description | Default | -| ----------------------------- | ---------------------------------------------------------------------------------- |------------------------------------- | -| OTEL_EXPORTER_ZIPKIN_ENDPOINT | Endpoint for Zipkin traces | `http://localhost:9411/api/v2/spans` | -| OTEL_EXPORTER_ZIPKIN_TIMEOUT | Maximum time (in milliseconds) the Zipkin exporter will wait for each batch export | 10000 | +| Name | Description | Default | [Type](#configuration-types) | +|-------------------------------|------------------------------------------------------------------------------------|--------------------------------------|------------------------------| +| OTEL_EXPORTER_ZIPKIN_ENDPOINT | Endpoint for Zipkin traces | `http://localhost:9411/api/v2/spans` | `string` | +| OTEL_EXPORTER_ZIPKIN_TIMEOUT | Maximum time (in milliseconds) the Zipkin exporter will wait for each batch export | 10000 | `integer` | Additionally, the following environment variables are reserved for future usage in Zipkin Exporter configuration: @@ -228,20 +253,20 @@ _is no specified default, or configuration via environment variables_. **Status**: [Development](../document-status.md) -| Name | Description | Default | -| ----------------------------- | --------------------------------| ---------------------------- | -| OTEL_EXPORTER_PROMETHEUS_HOST | Host used by the Prometheus exporter | "localhost" | -| OTEL_EXPORTER_PROMETHEUS_PORT | Port used by the Prometheus exporter | 9464 | +| Name | Description | Default | [Type](#configuration-types) | +|-------------------------------|--------------------------------------|-------------|------------------------------| +| OTEL_EXPORTER_PROMETHEUS_HOST | Host used by the Prometheus exporter | "localhost" | `string` | +| OTEL_EXPORTER_PROMETHEUS_PORT | Port used by the Prometheus exporter | 9464 | `integer` | ## Exporter Selection We define environment variables for setting one or more exporters per signal. -| Name | Description | Default | -| ------------- | ---------------------------------------------------------------------------- | ------- | -| OTEL_TRACES_EXPORTER | Trace exporter to be used | "otlp" | -| OTEL_METRICS_EXPORTER | Metrics exporter to be used | "otlp" | -| OTEL_LOGS_EXPORTER | Logs exporter to be used | "otlp" | +| Name | Description | Default | [Type](#configuration-types) | +|-----------------------|-----------------------------|---------|------------------------------| +| OTEL_TRACES_EXPORTER | Trace exporter to be used | "otlp" | `enum` | +| OTEL_METRICS_EXPORTER | Metrics exporter to be used | "otlp" | `enum` | +| OTEL_LOGS_EXPORTER | Logs exporter to be used | "otlp" | `enum` | The implementation MAY accept a comma-separated list to enable setting multiple exporters. @@ -293,9 +318,9 @@ Additional known values for `OTEL_LOGS_EXPORTER` are: ### Exemplar -| Name | Description | Default | Notes | -|-----------------|---------|-------------|---------| -| `OTEL_METRICS_EXEMPLAR_FILTER` | Filter for which measurements can become Exemplars. | `"trace_based"` | | +| Name | Description | Default | [Type](#configuration-types) | Notes | +|--------------------------------|-----------------------------------------------------|-----------------|------------------------------|-------| +| `OTEL_METRICS_EXEMPLAR_FILTER` | Filter for which measurements can become Exemplars. | `"trace_based"` | `enum` | | Known values for `OTEL_METRICS_EXEMPLAR_FILTER` are: @@ -308,10 +333,10 @@ Known values for `OTEL_METRICS_EXEMPLAR_FILTER` are: Environment variables specific for the push metrics exporters (OTLP, stdout, in-memory) that use [periodic exporting MetricReader](../metrics/sdk.md#periodic-exporting-metricreader). -| Name | Description | Default | Notes | -| ----------------------------- | ----------------------------------------------------------------------------- | ------- | ----- | -| `OTEL_METRIC_EXPORT_INTERVAL` | The time interval (in milliseconds) between the start of two export attempts. | 60000 | | -| `OTEL_METRIC_EXPORT_TIMEOUT` | Maximum allowed time (in milliseconds) to export data. | 30000 | | +| Name | Description | Default | [Type](#configuration-types) | Notes | +|-------------------------------|-------------------------------------------------------------------------------|---------|------------------------------|-------| +| `OTEL_METRIC_EXPORT_INTERVAL` | The time interval (in milliseconds) between the start of two export attempts. | 60000 | `duration` | | +| `OTEL_METRIC_EXPORT_TIMEOUT` | Maximum allowed time (in milliseconds) to export data. | 30000 | `duration` | | ## Declarative configuration @@ -319,9 +344,9 @@ that use [periodic exporting MetricReader](../metrics/sdk.md#periodic-exporting- Environment variables involved in [declarative configuration](./README.md#declarative-configuration). -| Name | Description | Default | Notes | -|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------| -| OTEL_EXPERIMENTAL_CONFIG_FILE | The path of the configuration file used to configure the SDK. If set, the configuration in this file takes precedence over all other SDK configuration environment variables. | | See below | +| Name | Description | Default | [Type](#configuration-types) | Notes | +|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------------------|-----------| +| OTEL_EXPERIMENTAL_CONFIG_FILE | The path of the configuration file used to configure the SDK. If set, the configuration in this file takes precedence over all other SDK configuration environment variables. | | `string` | See below | If `OTEL_EXPERIMENTAL_CONFIG_FILE` is set, the file at the specified path is used to call [Parse](./sdk.md#parse). The diff --git a/specification/metrics/sdk_exporters/otlp.md b/specification/metrics/sdk_exporters/otlp.md index 5b22516e883..9afec79975b 100644 --- a/specification/metrics/sdk_exporters/otlp.md +++ b/specification/metrics/sdk_exporters/otlp.md @@ -42,10 +42,10 @@ then by default: ## Additional Environment Variable Configuration -| Name | Description | Default | -|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------| -| `OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE` | Configure the exporter's aggregation `temporality` option (see above) on the basis of instrument kind. | `cumulative` | -| `OTEL_EXPORTER_OTLP_METRICS_DEFAULT_HISTOGRAM_AGGREGATION` | Configure the exporter's `default_aggregation` option (see above) for Histogram instrument kind. | `explicit_bucket_histogram` | +| Name | Description | Default | [Type](../../configuration/sdk-environment-variables.md#configuration-types) | +|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------|------------------------------------------------------------------------------| +| `OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE` | Configure the exporter's aggregation `temporality` option (see above) on the basis of instrument kind. | `cumulative` | `enum` | +| `OTEL_EXPORTER_OTLP_METRICS_DEFAULT_HISTOGRAM_AGGREGATION` | Configure the exporter's `default_aggregation` option (see above) for Histogram instrument kind. | `explicit_bucket_histogram` | `enum` | The recognized (case-insensitive) values for `OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE` are: diff --git a/specification/protocol/exporter.md b/specification/protocol/exporter.md index 22cf934c613..5c8a5673ebe 100644 --- a/specification/protocol/exporter.md +++ b/specification/protocol/exporter.md @@ -26,43 +26,53 @@ Each configuration option MUST be overridable by a signal specific option. When using `OTEL_EXPORTER_OTLP_ENDPOINT`, exporters MUST construct per-signal URLs as [described below](#endpoint-urls-for-otlphttp). The per-signal endpoint configuration options take precedence and can be used to override this behavior (the URL is used as-is for them, without any modifications). See the [OTLP Specification][otlphttp-req] for more details. - Default: `http://localhost:4318` [1] - Env vars: `OTEL_EXPORTER_OTLP_ENDPOINT` `OTEL_EXPORTER_OTLP_TRACES_ENDPOINT` `OTEL_EXPORTER_OTLP_METRICS_ENDPOINT` `OTEL_EXPORTER_OTLP_LOGS_ENDPOINT` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` - **Endpoint (OTLP/gRPC)**: Target to which the exporter is going to send spans, metrics, or logs. The option SHOULD accept any form allowed by the underlying gRPC client implementation. Additionally, the option MUST accept a URL with a scheme of either `http` or `https`. A scheme of `https` indicates a secure connection and takes precedence over the `insecure` configuration setting. A scheme of `http` indicates an insecure connection and takes precedence over the `insecure` configuration setting. If the gRPC client implementation does not support an endpoint with a scheme of `http` or `https` then the endpoint SHOULD be transformed to the most sensible format for that implementation. - Default: `http://localhost:4317` [1] - Env vars: `OTEL_EXPORTER_OTLP_ENDPOINT` `OTEL_EXPORTER_OTLP_TRACES_ENDPOINT` `OTEL_EXPORTER_OTLP_METRICS_ENDPOINT` `OTEL_EXPORTER_OTLP_LOGS_ENDPOINT` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` - **Insecure**: Whether to enable client transport security for the exporter's gRPC connection. This option only applies to OTLP/gRPC when an endpoint is provided without the `http` or `https` scheme - OTLP/HTTP always uses the scheme provided for the `endpoint`. Implementations MAY choose to not implement the `insecure` option if it is not required or supported by the underlying gRPC client implementation. - Default: `false` - Env vars: `OTEL_EXPORTER_OTLP_INSECURE` `OTEL_EXPORTER_OTLP_TRACES_INSECURE` `OTEL_EXPORTER_OTLP_METRICS_INSECURE` `OTEL_EXPORTER_OTLP_LOGS_INSECURE` [2] + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `boolean` - **Certificate File**: The trusted certificate to use when verifying a server's TLS credentials. Should only be used for a secure connection. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_CERTIFICATE` `OTEL_EXPORTER_OTLP_TRACES_CERTIFICATE` `OTEL_EXPORTER_OTLP_METRICS_CERTIFICATE` `OTEL_EXPORTER_OTLP_LOGS_CERTIFICATE` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` - **Client key file**: Clients private key to use in mTLS communication in PEM format. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_CLIENT_KEY` `OTEL_EXPORTER_OTLP_TRACES_CLIENT_KEY` `OTEL_EXPORTER_OTLP_METRICS_CLIENT_KEY` `OTEL_EXPORTER_OTLP_LOGS_CLIENT_KEY` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` - **Client certificate file**: Client certificate/chain trust for clients private key to use in mTLS communication in PEM format. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_CLIENT_CERTIFICATE` `OTEL_EXPORTER_OTLP_TRACES_CLIENT_CERTIFICATE` `OTEL_EXPORTER_OTLP_METRICS_CLIENT_CERTIFICATE` `OTEL_EXPORTER_OTLP_LOGS_CLIENT_CERTIFICATE` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` - **Headers**: Key-value pairs to be used as headers associated with gRPC or HTTP requests. See [Specifying headers](./exporter.md#specifying-headers-via-environment-variables) for more details. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_HEADERS` `OTEL_EXPORTER_OTLP_TRACES_HEADERS` `OTEL_EXPORTER_OTLP_METRICS_HEADERS` `OTEL_EXPORTER_OTLP_LOGS_HEADERS` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` - **Compression**: Compression key for supported compression types. Supported compression: `gzip`. - Default: No value [3] - Env vars: `OTEL_EXPORTER_OTLP_COMPRESSION` `OTEL_EXPORTER_OTLP_TRACES_COMPRESSION` `OTEL_EXPORTER_OTLP_METRICS_COMPRESSION` `OTEL_EXPORTER_OTLP_LOGS_COMPRESSION` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `enum` - **Timeout**: Maximum time the OTLP exporter will wait for each batch export. - Default: 10s - Env vars: `OTEL_EXPORTER_OTLP_TIMEOUT` `OTEL_EXPORTER_OTLP_TRACES_TIMEOUT` `OTEL_EXPORTER_OTLP_METRICS_TIMEOUT` `OTEL_EXPORTER_OTLP_LOGS_TIMEOUT` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `duration` - **Protocol**: The transport protocol. Options MUST be one of: `grpc`, `http/protobuf`, `http/json`. See [Specify Protocol](./exporter.md#specify-protocol) for more details. - Default: `http/protobuf` - Env vars: `OTEL_EXPORTER_OTLP_PROTOCOL` `OTEL_EXPORTER_OTLP_TRACES_PROTOCOL` `OTEL_EXPORTER_OTLP_METRICS_PROTOCOL` `OTEL_EXPORTER_OTLP_LOGS_PROTOCOL` + - [Type](../configuration/sdk-environment-variables.md#configuration-types): `enum` **[1]**: SDKs SHOULD default endpoint variables to use `http` scheme unless they have good reasons to choose `https` scheme for the default (e.g., for backward compatibility reasons in a stable SDK release). From 3821ce15c3ef93a40b0894c1f9bb0e12b0e45b31 Mon Sep 17 00:00:00 2001 From: Jack Berg Date: Wed, 11 Dec 2024 17:17:43 -0600 Subject: [PATCH 2/6] formatting --- .../sdk-environment-variables.md | 67 ++++++++++++------- 1 file changed, 42 insertions(+), 25 deletions(-) diff --git a/specification/configuration/sdk-environment-variables.md b/specification/configuration/sdk-environment-variables.md index 35cac76b047..5585cb7d10e 100644 --- a/specification/configuration/sdk-environment-variables.md +++ b/specification/configuration/sdk-environment-variables.md @@ -65,12 +65,17 @@ The SDK MUST interpret an empty value of an environment variable the same way as ### Boolean -Any value that represents a Boolean MUST be set to true only by the case-insensitive string `"true"`, meaning `"True"` or `"TRUE"` are also accepted, as true. -An implementation MUST NOT extend this definition and define additional values that are interpreted as true. -Any value not explicitly defined here as a true value, including unset and empty values, MUST be interpreted as false. -If any value other than a true value, case-insensitive string `"false"`, empty, or unset is used, a warning SHOULD be logged to inform users about the fallback to false being applied. -All Boolean environment variables SHOULD be named and defined such that false is the expected safe default behavior. -Renaming or changing the default value MUST NOT happen without a major version upgrade. +Any value that represents a Boolean MUST be set to true only by the +case-insensitive string `"true"`, meaning `"True"` or `"TRUE"` are also +accepted, as true. An implementation MUST NOT extend this definition and define +additional values that are interpreted as true. Any value not explicitly defined +here as a true value, including unset and empty values, MUST be interpreted as +false. If any value other than a true value, case-insensitive string `"false"`, +empty, or unset is used, a warning SHOULD be logged to inform users about the +fallback to false being applied. All Boolean environment variables SHOULD be +named and defined such that false is the expected safe default behavior. +Renaming or changing the default value MUST NOT happen without a major version +upgrade. ### Numeric @@ -87,34 +92,41 @@ The following guidance applies to all numeric types. > For new > implementations, these should be treated as MUST requirements. -For variables accepting a numeric value, if the user provides a value the implementation cannot parse, -or which is outside the valid range for the configuration item, the implementation SHOULD -generate a warning and gracefully ignore the setting, i.e., treat them as not set. -In particular, implementations +For variables accepting a numeric value, if the user provides a value the +implementation cannot parse, or which is outside the valid range for the +configuration item, the implementation SHOULD generate a warning and gracefully +ignore the setting, i.e., treat them as not set. In particular, implementations SHOULD NOT assign a custom interpretation e.g. to negative values if a negative -value does not naturally apply to a configuration and does not have an explicitly specified meaning, but treat it like any other -invalid value. +value does not naturally apply to a configuration and does not have an +explicitly specified meaning, but treat it like any other invalid value. For example, a value specifying a buffer size must naturally be non-negative. -Treating a negative value as "buffer everything" would be an example of such a discouraged custom interpretation. -Instead the default buffer size should be used. +Treating a negative value as "buffer everything" would be an example of such a +discouraged custom interpretation. Instead the default buffer size should be +used. -Note that this could make a difference even if the custom interpretation is identical with the default value, -because it might reset a value set from other configuration sources with the default. +Note that this could make a difference even if the custom interpretation is +identical with the default value, because it might reset a value set from other +configuration sources with the default. #### Float -If an implementation chooses to support a float-valued environment variable, it SHOULD support single precision floating point (IEEE 754-1985). Individual SDKs MAY choose to support a larger range of values. +If an implementation chooses to support a float-valued environment variable, it +SHOULD support single precision floating point (IEEE 754-1985). Individual SDKs +MAY choose to support a larger range of values. #### Integer -If an implementation chooses to support an integer-valued environment variable, it SHOULD support nonnegative values between 0 and 2³¹ − 1 (inclusive). Individual SDKs MAY choose to support a larger range of values. +If an implementation chooses to support an integer-valued environment variable, +it SHOULD support nonnegative values between 0 and 2³¹ − 1 (inclusive). +Individual SDKs MAY choose to support a larger range of values. #### Duration -Any value that represents a duration, for example a timeout, MUST be an integer representing a number of -milliseconds. The value is non-negative - if a negative value is provided, the implementation MUST generate a warning, -gracefully ignore the setting and use the default value if it is defined. +Any value that represents a duration, for example a timeout, MUST be an integer +representing a number of milliseconds. The value is non-negative - if a negative +value is provided, the implementation MUST generate a warning, gracefully ignore +the setting and use the default value if it is defined. For example, the value `12000` indicates 12000 milliseconds, i.e., 12 seconds. @@ -124,14 +136,19 @@ String values are sub-classified into: * [enum](#enum). -Normally, string values includes notes describing how they are interpreted by implementations. +Normally, string values includes notes describing how they are interpreted by +implementations. #### Enum -For variables which accept a known value out of a set, i.e., an enum value, implementations MAY support additional values not listed here. -For variables accepting an enum value, if the user provides a value the implementation does not recognize, the implementation MUST generate a warning and gracefully ignore the setting. +For variables which accept a known value out of a set, i.e., an enum value, +implementations MAY support additional values not listed here. For variables +accepting an enum value, if the user provides a value the implementation does +not recognize, the implementation MUST generate a warning and gracefully ignore +the setting. -If a null object (empty, no-op) value is acceptable, then the enum value representing it MUST be `"none"`. +If a null object (empty, no-op) value is acceptable, then the enum value +representing it MUST be `"none"`. ## General SDK Configuration From 45b346a77a2a6430d890e4ca595c44db462024b9 Mon Sep 17 00:00:00 2001 From: Jack Berg Date: Fri, 13 Dec 2024 11:22:31 -0600 Subject: [PATCH 3/6] PR feedback --- .../sdk-environment-variables.md | 135 +++++++++--------- specification/protocol/exporter.md | 25 ++-- 2 files changed, 86 insertions(+), 74 deletions(-) diff --git a/specification/configuration/sdk-environment-variables.md b/specification/configuration/sdk-environment-variables.md index 5585cb7d10e..998f1d3be97 100644 --- a/specification/configuration/sdk-environment-variables.md +++ b/specification/configuration/sdk-environment-variables.md @@ -81,9 +81,9 @@ upgrade. Variables accepting numeric values are sub-classified into: -* [integer](#integer) -* [float](#float) -* [duration](#duration) +* [Float](#float) +* [Integer](#integer) +* [Duration](#duration) The following guidance applies to all numeric types. @@ -134,7 +134,7 @@ For example, the value `12000` indicates 12000 milliseconds, i.e., 12 seconds. String values are sub-classified into: -* [enum](#enum). +* [Enum](#enum). Normally, string values includes notes describing how they are interpreted by implementations. @@ -152,15 +152,15 @@ representing it MUST be `"none"`. ## General SDK Configuration -| Name | Description | Default | [Type](#configuration-types) | Notes | -|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| OTEL_SDK_DISABLED | Disable the SDK for all signals | false | `boolean` | If "true", a no-op SDK implementation will be used for all telemetry signals. Any other value or absence of the variable will have no effect and the SDK will remain enabled. This setting has no effect on propagators configured through the OTEL_PROPAGATORS variable. | -| OTEL_RESOURCE_ATTRIBUTES | Key-value pairs to be used as resource attributes | See [Resource semantic conventions](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#semantic-attributes-with-dedicated-environment-variable) for details. | `string` | See [Resource SDK](../resource/sdk.md#specifying-resource-information-via-an-environment-variable) for more details. | -| OTEL_SERVICE_NAME | Sets the value of the [`service.name`](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#service) resource attribute | | `string` | If `service.name` is also provided in `OTEL_RESOURCE_ATTRIBUTES`, then `OTEL_SERVICE_NAME` takes precedence. | -| OTEL_LOG_LEVEL | Log level used by the [SDK internal logger](../error-handling.md#self-diagnostics) | "info" | `enum` | | -| OTEL_PROPAGATORS | Propagators to be used as a comma-separated list | "tracecontext,baggage" | `enum` | Values MUST be deduplicated in order to register a `Propagator` only once. | -| OTEL_TRACES_SAMPLER | Sampler to be used for traces | "parentbased_always_on" | `enum` | See [Sampling](../trace/sdk.md#sampling) | -| OTEL_TRACES_SAMPLER_ARG | String value to be used as the sampler argument | | `float` or `string` | The specified value will only be used if OTEL_TRACES_SAMPLER is set. Each Sampler type defines its own expected input, if any. Invalid or unrecognized input MUST be logged and MUST be otherwise ignored, i.e. the implementation MUST behave as if OTEL_TRACES_SAMPLER_ARG is not set. | +| Name | Description | Default | Type | Notes | +|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| +| OTEL_SDK_DISABLED | Disable the SDK for all signals | false | [Boolean][] | If "true", a no-op SDK implementation will be used for all telemetry signals. Any other value or absence of the variable will have no effect and the SDK will remain enabled. This setting has no effect on propagators configured through the OTEL_PROPAGATORS variable. | +| OTEL_RESOURCE_ATTRIBUTES | Key-value pairs to be used as resource attributes | See [Resource semantic conventions](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#semantic-attributes-with-dedicated-environment-variable) for details. | [String][] | See [Resource SDK](../resource/sdk.md#specifying-resource-information-via-an-environment-variable) for more details. | +| OTEL_SERVICE_NAME | Sets the value of the [`service.name`](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#service) resource attribute | | [String][] | If `service.name` is also provided in `OTEL_RESOURCE_ATTRIBUTES`, then `OTEL_SERVICE_NAME` takes precedence. | +| OTEL_LOG_LEVEL | Log level used by the [SDK internal logger](../error-handling.md#self-diagnostics) | "info" | [Enum][] | | +| OTEL_PROPAGATORS | Propagators to be used as a comma-separated list | "tracecontext,baggage" | [Enum][] | Values MUST be deduplicated in order to register a `Propagator` only once. | +| OTEL_TRACES_SAMPLER | Sampler to be used for traces | "parentbased_always_on" | [Enum][] | See [Sampling](../trace/sdk.md#sampling) | +| OTEL_TRACES_SAMPLER_ARG | Value to be used as the sampler argument | | [Float][] or [String][] | The specified value will only be used if OTEL_TRACES_SAMPLER is set. Each Sampler type defines its own expected input, if any. Invalid or unrecognized input MUST be logged and MUST be otherwise ignored, i.e. the implementation MUST behave as if OTEL_TRACES_SAMPLER_ARG is not set. | Known values for `OTEL_PROPAGATORS` are: @@ -196,21 +196,21 @@ Depending on the value of `OTEL_TRACES_SAMPLER`, `OTEL_TRACES_SAMPLER_ARG` may b ## Batch Span Processor -| Name | Description | Default | [Type](#configuration-types) | Notes | -|--------------------------------|------------------------------------------------------------------|---------|------------------------------|-------------------------------------------------------| -| OTEL_BSP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 5000 | `duration` | | -| OTEL_BSP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | `duration` | | -| OTEL_BSP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | `integer` | | -| OTEL_BSP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | `integer` | Must be less than or equal to OTEL_BSP_MAX_QUEUE_SIZE | +| Name | Description | Default | Type | Notes | +|--------------------------------|------------------------------------------------------------------|---------|--------------|-------------------------------------------------------| +| OTEL_BSP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 5000 | [Duration][] | | +| OTEL_BSP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | [Duration][] | | +| OTEL_BSP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | [Integer][] | | +| OTEL_BSP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | [Integer][] | Must be less than or equal to OTEL_BSP_MAX_QUEUE_SIZE | ## Batch LogRecord Processor -| Name | Description | Default | [Type](#configuration-types) | Notes | -|---------------------------------|------------------------------------------------------------------|---------|------------------------------|--------------------------------------------------------| -| OTEL_BLRP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 1000 | `duration` | | -| OTEL_BLRP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | `duration` | | -| OTEL_BLRP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | `integer` | | -| OTEL_BLRP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | `integer` | Must be less than or equal to OTEL_BLRP_MAX_QUEUE_SIZE | +| Name | Description | Default | Type | Notes | +|---------------------------------|------------------------------------------------------------------|---------|--------------|--------------------------------------------------------| +| OTEL_BLRP_SCHEDULE_DELAY | Delay interval (in milliseconds) between two consecutive exports | 1000 | [Duration][] | | +| OTEL_BLRP_EXPORT_TIMEOUT | Maximum allowed time (in milliseconds) to export data | 30000 | [Duration][] | | +| OTEL_BLRP_MAX_QUEUE_SIZE | Maximum queue size | 2048 | [Integer][] | | +| OTEL_BLRP_MAX_EXPORT_BATCH_SIZE | Maximum batch size | 512 | [Integer][] | Must be less than or equal to OTEL_BLRP_MAX_QUEUE_SIZE | ## Attribute Limits @@ -219,32 +219,32 @@ which that SDK implements truncation mechanism. See the SDK [Attribute Limits](../common/README.md#attribute-limits) section for the definition of the limits. -| Name | Description | Default | [Type](#configuration-types) | -|-----------------------------------|--------------------------------------|----------|------------------------------| -| OTEL_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | `integer` | -| OTEL_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute count | 128 | `integer` | +| Name | Description | Default | Type | +|-----------------------------------|--------------------------------------|----------|-------------| +| OTEL_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | [Integer][] | +| OTEL_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute count | 128 | [Integer][] | ## Span Limits See the SDK [Span Limits](../trace/sdk.md#span-limits) section for the definition of the limits. -| Name | Description | Default | [Type](#configuration-types) | -|----------------------------------------|------------------------------------------------|----------|------------------------------| -| OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | `integer` | -| OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT | Maximum allowed span attribute count | 128 | `integer` | -| OTEL_SPAN_EVENT_COUNT_LIMIT | Maximum allowed span event count | 128 | `integer` | -| OTEL_SPAN_LINK_COUNT_LIMIT | Maximum allowed span link count | 128 | `integer` | -| OTEL_EVENT_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span event count | 128 | `integer` | -| OTEL_LINK_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span link count | 128 | `integer` | +| Name | Description | Default | Type | +|----------------------------------------|------------------------------------------------|----------|-------------| +| OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | [Integer][] | +| OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT | Maximum allowed span attribute count | 128 | [Integer][] | +| OTEL_SPAN_EVENT_COUNT_LIMIT | Maximum allowed span event count | 128 | [Integer][] | +| OTEL_SPAN_LINK_COUNT_LIMIT | Maximum allowed span link count | 128 | [Integer][] | +| OTEL_EVENT_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span event count | 128 | [Integer][] | +| OTEL_LINK_ATTRIBUTE_COUNT_LIMIT | Maximum allowed attribute per span link count | 128 | [Integer][] | ## LogRecord Limits See the SDK [LogRecord Limits](../logs/sdk.md#logrecord-limits) section for the definition of the limits. -| Name | Description | Default | [Type](#configuration-types) | -|---------------------------------------------|--------------------------------------------|----------|------------------------------| -| OTEL_LOGRECORD_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | `integer` | -| OTEL_LOGRECORD_ATTRIBUTE_COUNT_LIMIT | Maximum allowed log record attribute count | 128 | `integer` | +| Name | Description | Default | Type | +|---------------------------------------------|--------------------------------------------|----------|-------------| +| OTEL_LOGRECORD_ATTRIBUTE_VALUE_LENGTH_LIMIT | Maximum allowed attribute value size | no limit | [Integer][] | +| OTEL_LOGRECORD_ATTRIBUTE_COUNT_LIMIT | Maximum allowed log record attribute count | 128 | [Integer][] | ## OTLP Exporter @@ -252,10 +252,10 @@ See [OpenTelemetry Protocol Exporter Configuration Options](../protocol/exporter ## Zipkin Exporter -| Name | Description | Default | [Type](#configuration-types) | -|-------------------------------|------------------------------------------------------------------------------------|--------------------------------------|------------------------------| -| OTEL_EXPORTER_ZIPKIN_ENDPOINT | Endpoint for Zipkin traces | `http://localhost:9411/api/v2/spans` | `string` | -| OTEL_EXPORTER_ZIPKIN_TIMEOUT | Maximum time (in milliseconds) the Zipkin exporter will wait for each batch export | 10000 | `integer` | +| Name | Description | Default | Type | +|-------------------------------|------------------------------------------------------------------------------------|--------------------------------------|-------------| +| OTEL_EXPORTER_ZIPKIN_ENDPOINT | Endpoint for Zipkin traces | `http://localhost:9411/api/v2/spans` | [String][] | +| OTEL_EXPORTER_ZIPKIN_TIMEOUT | Maximum time (in milliseconds) the Zipkin exporter will wait for each batch export | 10000 | [Integer][] | Additionally, the following environment variables are reserved for future usage in Zipkin Exporter configuration: @@ -270,20 +270,20 @@ _is no specified default, or configuration via environment variables_. **Status**: [Development](../document-status.md) -| Name | Description | Default | [Type](#configuration-types) | -|-------------------------------|--------------------------------------|-------------|------------------------------| -| OTEL_EXPORTER_PROMETHEUS_HOST | Host used by the Prometheus exporter | "localhost" | `string` | -| OTEL_EXPORTER_PROMETHEUS_PORT | Port used by the Prometheus exporter | 9464 | `integer` | +| Name | Description | Default | Type | +|-------------------------------|--------------------------------------|-------------|-------------| +| OTEL_EXPORTER_PROMETHEUS_HOST | Host used by the Prometheus exporter | "localhost" | [String][] | +| OTEL_EXPORTER_PROMETHEUS_PORT | Port used by the Prometheus exporter | 9464 | [Integer][] | ## Exporter Selection We define environment variables for setting one or more exporters per signal. -| Name | Description | Default | [Type](#configuration-types) | -|-----------------------|-----------------------------|---------|------------------------------| -| OTEL_TRACES_EXPORTER | Trace exporter to be used | "otlp" | `enum` | -| OTEL_METRICS_EXPORTER | Metrics exporter to be used | "otlp" | `enum` | -| OTEL_LOGS_EXPORTER | Logs exporter to be used | "otlp" | `enum` | +| Name | Description | Default | Type | +|-----------------------|-----------------------------|---------|----------| +| OTEL_TRACES_EXPORTER | Trace exporter to be used | "otlp" | [Enum][] | +| OTEL_METRICS_EXPORTER | Metrics exporter to be used | "otlp" | [Enum][] | +| OTEL_LOGS_EXPORTER | Logs exporter to be used | "otlp" | [Enum][] | The implementation MAY accept a comma-separated list to enable setting multiple exporters. @@ -335,9 +335,9 @@ Additional known values for `OTEL_LOGS_EXPORTER` are: ### Exemplar -| Name | Description | Default | [Type](#configuration-types) | Notes | -|--------------------------------|-----------------------------------------------------|-----------------|------------------------------|-------| -| `OTEL_METRICS_EXEMPLAR_FILTER` | Filter for which measurements can become Exemplars. | `"trace_based"` | `enum` | | +| Name | Description | Default | Type | Notes | +|--------------------------------|-----------------------------------------------------|-----------------|----------|-------| +| `OTEL_METRICS_EXEMPLAR_FILTER` | Filter for which measurements can become Exemplars. | `"trace_based"` | [Enum][] | | Known values for `OTEL_METRICS_EXEMPLAR_FILTER` are: @@ -350,10 +350,10 @@ Known values for `OTEL_METRICS_EXEMPLAR_FILTER` are: Environment variables specific for the push metrics exporters (OTLP, stdout, in-memory) that use [periodic exporting MetricReader](../metrics/sdk.md#periodic-exporting-metricreader). -| Name | Description | Default | [Type](#configuration-types) | Notes | -|-------------------------------|-------------------------------------------------------------------------------|---------|------------------------------|-------| -| `OTEL_METRIC_EXPORT_INTERVAL` | The time interval (in milliseconds) between the start of two export attempts. | 60000 | `duration` | | -| `OTEL_METRIC_EXPORT_TIMEOUT` | Maximum allowed time (in milliseconds) to export data. | 30000 | `duration` | | +| Name | Description | Default | Type | Notes | +|-------------------------------|-------------------------------------------------------------------------------|---------|--------------|-------| +| `OTEL_METRIC_EXPORT_INTERVAL` | The time interval (in milliseconds) between the start of two export attempts. | 60000 | [Duration][] | | +| `OTEL_METRIC_EXPORT_TIMEOUT` | Maximum allowed time (in milliseconds) to export data. | 30000 | [Duration][] | | ## Declarative configuration @@ -361,9 +361,9 @@ that use [periodic exporting MetricReader](../metrics/sdk.md#periodic-exporting- Environment variables involved in [declarative configuration](./README.md#declarative-configuration). -| Name | Description | Default | [Type](#configuration-types) | Notes | -|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------------------|-----------| -| OTEL_EXPERIMENTAL_CONFIG_FILE | The path of the configuration file used to configure the SDK. If set, the configuration in this file takes precedence over all other SDK configuration environment variables. | | `string` | See below | +| Name | Description | Default | Type | Notes | +|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------|-----------| +| OTEL_EXPERIMENTAL_CONFIG_FILE | The path of the configuration file used to configure the SDK. If set, the configuration in this file takes precedence over all other SDK configuration environment variables. | | [String][] | See below | If `OTEL_EXPERIMENTAL_CONFIG_FILE` is set, the file at the specified path is used to call [Parse](./sdk.md#parse). The @@ -402,3 +402,10 @@ To ensure consistent naming across projects, this specification recommends that ``` OTEL_{LANGUAGE}_{FEATURE} ``` + +[Boolean]: #boolean +[Float]: #float +[Integer]: #integer +[Duration]: #duration +[String]: #string +[Enum]: #enum diff --git a/specification/protocol/exporter.md b/specification/protocol/exporter.md index 5c8a5673ebe..74b65e1caf9 100644 --- a/specification/protocol/exporter.md +++ b/specification/protocol/exporter.md @@ -26,53 +26,53 @@ Each configuration option MUST be overridable by a signal specific option. When using `OTEL_EXPORTER_OTLP_ENDPOINT`, exporters MUST construct per-signal URLs as [described below](#endpoint-urls-for-otlphttp). The per-signal endpoint configuration options take precedence and can be used to override this behavior (the URL is used as-is for them, without any modifications). See the [OTLP Specification][otlphttp-req] for more details. - Default: `http://localhost:4318` [1] - Env vars: `OTEL_EXPORTER_OTLP_ENDPOINT` `OTEL_EXPORTER_OTLP_TRACES_ENDPOINT` `OTEL_EXPORTER_OTLP_METRICS_ENDPOINT` `OTEL_EXPORTER_OTLP_LOGS_ENDPOINT` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` + - Type: [String][] - **Endpoint (OTLP/gRPC)**: Target to which the exporter is going to send spans, metrics, or logs. The option SHOULD accept any form allowed by the underlying gRPC client implementation. Additionally, the option MUST accept a URL with a scheme of either `http` or `https`. A scheme of `https` indicates a secure connection and takes precedence over the `insecure` configuration setting. A scheme of `http` indicates an insecure connection and takes precedence over the `insecure` configuration setting. If the gRPC client implementation does not support an endpoint with a scheme of `http` or `https` then the endpoint SHOULD be transformed to the most sensible format for that implementation. - Default: `http://localhost:4317` [1] - Env vars: `OTEL_EXPORTER_OTLP_ENDPOINT` `OTEL_EXPORTER_OTLP_TRACES_ENDPOINT` `OTEL_EXPORTER_OTLP_METRICS_ENDPOINT` `OTEL_EXPORTER_OTLP_LOGS_ENDPOINT` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` + - Type: [String][] - **Insecure**: Whether to enable client transport security for the exporter's gRPC connection. This option only applies to OTLP/gRPC when an endpoint is provided without the `http` or `https` scheme - OTLP/HTTP always uses the scheme provided for the `endpoint`. Implementations MAY choose to not implement the `insecure` option if it is not required or supported by the underlying gRPC client implementation. - Default: `false` - Env vars: `OTEL_EXPORTER_OTLP_INSECURE` `OTEL_EXPORTER_OTLP_TRACES_INSECURE` `OTEL_EXPORTER_OTLP_METRICS_INSECURE` `OTEL_EXPORTER_OTLP_LOGS_INSECURE` [2] - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `boolean` + - Type: [Boolean[] - **Certificate File**: The trusted certificate to use when verifying a server's TLS credentials. Should only be used for a secure connection. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_CERTIFICATE` `OTEL_EXPORTER_OTLP_TRACES_CERTIFICATE` `OTEL_EXPORTER_OTLP_METRICS_CERTIFICATE` `OTEL_EXPORTER_OTLP_LOGS_CERTIFICATE` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` + - Type: [String][] - **Client key file**: Clients private key to use in mTLS communication in PEM format. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_CLIENT_KEY` `OTEL_EXPORTER_OTLP_TRACES_CLIENT_KEY` `OTEL_EXPORTER_OTLP_METRICS_CLIENT_KEY` `OTEL_EXPORTER_OTLP_LOGS_CLIENT_KEY` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` + - Type: [String][] - **Client certificate file**: Client certificate/chain trust for clients private key to use in mTLS communication in PEM format. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_CLIENT_CERTIFICATE` `OTEL_EXPORTER_OTLP_TRACES_CLIENT_CERTIFICATE` `OTEL_EXPORTER_OTLP_METRICS_CLIENT_CERTIFICATE` `OTEL_EXPORTER_OTLP_LOGS_CLIENT_CERTIFICATE` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` + - Type: [String][] - **Headers**: Key-value pairs to be used as headers associated with gRPC or HTTP requests. See [Specifying headers](./exporter.md#specifying-headers-via-environment-variables) for more details. - Default: n/a - Env vars: `OTEL_EXPORTER_OTLP_HEADERS` `OTEL_EXPORTER_OTLP_TRACES_HEADERS` `OTEL_EXPORTER_OTLP_METRICS_HEADERS` `OTEL_EXPORTER_OTLP_LOGS_HEADERS` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `string` + - Type: [String][] - **Compression**: Compression key for supported compression types. Supported compression: `gzip`. - Default: No value [3] - Env vars: `OTEL_EXPORTER_OTLP_COMPRESSION` `OTEL_EXPORTER_OTLP_TRACES_COMPRESSION` `OTEL_EXPORTER_OTLP_METRICS_COMPRESSION` `OTEL_EXPORTER_OTLP_LOGS_COMPRESSION` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `enum` + - Type: [Enum][] - **Timeout**: Maximum time the OTLP exporter will wait for each batch export. - Default: 10s - Env vars: `OTEL_EXPORTER_OTLP_TIMEOUT` `OTEL_EXPORTER_OTLP_TRACES_TIMEOUT` `OTEL_EXPORTER_OTLP_METRICS_TIMEOUT` `OTEL_EXPORTER_OTLP_LOGS_TIMEOUT` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `duration` + - Type: [Duration][] - **Protocol**: The transport protocol. Options MUST be one of: `grpc`, `http/protobuf`, `http/json`. See [Specify Protocol](./exporter.md#specify-protocol) for more details. - Default: `http/protobuf` - Env vars: `OTEL_EXPORTER_OTLP_PROTOCOL` `OTEL_EXPORTER_OTLP_TRACES_PROTOCOL` `OTEL_EXPORTER_OTLP_METRICS_PROTOCOL` `OTEL_EXPORTER_OTLP_LOGS_PROTOCOL` - - [Type](../configuration/sdk-environment-variables.md#configuration-types): `enum` + - Type: [Enum][] **[1]**: SDKs SHOULD default endpoint variables to use `http` scheme unless they have good reasons to choose `https` scheme for the default (e.g., for backward compatibility reasons in a stable SDK release). @@ -208,6 +208,11 @@ OTel-OTLP-Exporter-Python/1.2.3 The format of the header SHOULD follow [RFC 7231][rfc-7231]. The conventions used for specifying the OpenTelemetry SDK language and version are available in the [Resource semantic conventions][resource-semconv]. +[Boolean]: ../configuration/sdk-environment-variables.md#boolean +[Duration]: ../configuration/sdk-environment-variables.md#duration +[String]: ../configuration/sdk-environment-variables.md#string +[Enum]: ../configuration/sdk-environment-variables.md#enum + [resource-semconv]: https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#telemetry-sdk [otlphttp-req]: https://github.com/open-telemetry/opentelemetry-proto/blob/main/docs/specification.md#otlphttp-request [rfc-7231]: https://datatracker.ietf.org/doc/html/rfc7231#section-5.5.3 From 88bbf60a2e0ae13050bb8b512b7d6133d438a9fc Mon Sep 17 00:00:00 2001 From: Jack Berg Date: Fri, 13 Dec 2024 17:00:00 -0600 Subject: [PATCH 4/6] PR feedback --- .../configuration/sdk-environment-variables.md | 2 +- specification/metrics/sdk_exporters/otlp.md | 10 ++++++---- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/specification/configuration/sdk-environment-variables.md b/specification/configuration/sdk-environment-variables.md index 998f1d3be97..80af3c74f8a 100644 --- a/specification/configuration/sdk-environment-variables.md +++ b/specification/configuration/sdk-environment-variables.md @@ -136,7 +136,7 @@ String values are sub-classified into: * [Enum](#enum). -Normally, string values includes notes describing how they are interpreted by +Normally, string values include notes describing how they are interpreted by implementations. #### Enum diff --git a/specification/metrics/sdk_exporters/otlp.md b/specification/metrics/sdk_exporters/otlp.md index 9afec79975b..9c397648061 100644 --- a/specification/metrics/sdk_exporters/otlp.md +++ b/specification/metrics/sdk_exporters/otlp.md @@ -42,10 +42,10 @@ then by default: ## Additional Environment Variable Configuration -| Name | Description | Default | [Type](../../configuration/sdk-environment-variables.md#configuration-types) | -|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------|------------------------------------------------------------------------------| -| `OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE` | Configure the exporter's aggregation `temporality` option (see above) on the basis of instrument kind. | `cumulative` | `enum` | -| `OTEL_EXPORTER_OTLP_METRICS_DEFAULT_HISTOGRAM_AGGREGATION` | Configure the exporter's `default_aggregation` option (see above) for Histogram instrument kind. | `explicit_bucket_histogram` | `enum` | +| Name | Description | Default | Type | +|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------|----------| +| `OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE` | Configure the exporter's aggregation `temporality` option (see above) on the basis of instrument kind. | `cumulative` | [Enum][] | +| `OTEL_EXPORTER_OTLP_METRICS_DEFAULT_HISTOGRAM_AGGREGATION` | Configure the exporter's `default_aggregation` option (see above) for Histogram instrument kind. | `explicit_bucket_histogram` | [Enum][] | The recognized (case-insensitive) values for `OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE` are: @@ -71,3 +71,5 @@ The recognized (case-insensitive) values for `OTEL_EXPORTER_OTLP_METRICS_DEFAULT ## References - [OTEP0131 OTLP Exporters Configurable Export Behavior](https://github.com/open-telemetry/oteps/blob/main/text/metrics/0131-otlp-export-behavior.md) + +[Enum]: ../configuration/sdk-environment-variables.md#enum From 6eb866d90aac5ae02856e6308c1c1332018daa4d Mon Sep 17 00:00:00 2001 From: Jack Berg Date: Mon, 16 Dec 2024 17:40:34 -0600 Subject: [PATCH 5/6] Remove refs to float --- .../sdk-environment-variables.md | 26 +++++++------------ 1 file changed, 9 insertions(+), 17 deletions(-) diff --git a/specification/configuration/sdk-environment-variables.md b/specification/configuration/sdk-environment-variables.md index 80af3c74f8a..009fc5ee594 100644 --- a/specification/configuration/sdk-environment-variables.md +++ b/specification/configuration/sdk-environment-variables.md @@ -20,7 +20,6 @@ aliases: - [Configuration types](#configuration-types) * [Boolean](#boolean) * [Numeric](#numeric) - + [Float](#float) + [Integer](#integer) + [Duration](#duration) * [String](#string) @@ -81,7 +80,6 @@ upgrade. Variables accepting numeric values are sub-classified into: -* [Float](#float) * [Integer](#integer) * [Duration](#duration) @@ -109,12 +107,6 @@ Note that this could make a difference even if the custom interpretation is identical with the default value, because it might reset a value set from other configuration sources with the default. -#### Float - -If an implementation chooses to support a float-valued environment variable, it -SHOULD support single precision floating point (IEEE 754-1985). Individual SDKs -MAY choose to support a larger range of values. - #### Integer If an implementation chooses to support an integer-valued environment variable, @@ -152,15 +144,15 @@ representing it MUST be `"none"`. ## General SDK Configuration -| Name | Description | Default | Type | Notes | -|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| OTEL_SDK_DISABLED | Disable the SDK for all signals | false | [Boolean][] | If "true", a no-op SDK implementation will be used for all telemetry signals. Any other value or absence of the variable will have no effect and the SDK will remain enabled. This setting has no effect on propagators configured through the OTEL_PROPAGATORS variable. | -| OTEL_RESOURCE_ATTRIBUTES | Key-value pairs to be used as resource attributes | See [Resource semantic conventions](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#semantic-attributes-with-dedicated-environment-variable) for details. | [String][] | See [Resource SDK](../resource/sdk.md#specifying-resource-information-via-an-environment-variable) for more details. | -| OTEL_SERVICE_NAME | Sets the value of the [`service.name`](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#service) resource attribute | | [String][] | If `service.name` is also provided in `OTEL_RESOURCE_ATTRIBUTES`, then `OTEL_SERVICE_NAME` takes precedence. | -| OTEL_LOG_LEVEL | Log level used by the [SDK internal logger](../error-handling.md#self-diagnostics) | "info" | [Enum][] | | -| OTEL_PROPAGATORS | Propagators to be used as a comma-separated list | "tracecontext,baggage" | [Enum][] | Values MUST be deduplicated in order to register a `Propagator` only once. | -| OTEL_TRACES_SAMPLER | Sampler to be used for traces | "parentbased_always_on" | [Enum][] | See [Sampling](../trace/sdk.md#sampling) | -| OTEL_TRACES_SAMPLER_ARG | Value to be used as the sampler argument | | [Float][] or [String][] | The specified value will only be used if OTEL_TRACES_SAMPLER is set. Each Sampler type defines its own expected input, if any. Invalid or unrecognized input MUST be logged and MUST be otherwise ignored, i.e. the implementation MUST behave as if OTEL_TRACES_SAMPLER_ARG is not set. | +| Name | Description | Default | Type | Notes | +|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| +| OTEL_SDK_DISABLED | Disable the SDK for all signals | false | [Boolean][] | If "true", a no-op SDK implementation will be used for all telemetry signals. Any other value or absence of the variable will have no effect and the SDK will remain enabled. This setting has no effect on propagators configured through the OTEL_PROPAGATORS variable. | +| OTEL_RESOURCE_ATTRIBUTES | Key-value pairs to be used as resource attributes | See [Resource semantic conventions](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#semantic-attributes-with-dedicated-environment-variable) for details. | [String][] | See [Resource SDK](../resource/sdk.md#specifying-resource-information-via-an-environment-variable) for more details. | +| OTEL_SERVICE_NAME | Sets the value of the [`service.name`](https://github.com/open-telemetry/semantic-conventions/blob/main/docs/resource/README.md#service) resource attribute | | [String][] | If `service.name` is also provided in `OTEL_RESOURCE_ATTRIBUTES`, then `OTEL_SERVICE_NAME` takes precedence. | +| OTEL_LOG_LEVEL | Log level used by the [SDK internal logger](../error-handling.md#self-diagnostics) | "info" | [Enum][] | | +| OTEL_PROPAGATORS | Propagators to be used as a comma-separated list | "tracecontext,baggage" | [Enum][] | Values MUST be deduplicated in order to register a `Propagator` only once. | +| OTEL_TRACES_SAMPLER | Sampler to be used for traces | "parentbased_always_on" | [Enum][] | See [Sampling](../trace/sdk.md#sampling) | +| OTEL_TRACES_SAMPLER_ARG | Value to be used as the sampler argument | | See footnote | The specified value will only be used if OTEL_TRACES_SAMPLER is set. Each Sampler type defines its own expected input, if any. Invalid or unrecognized input MUST be logged and MUST be otherwise ignored, i.e. the implementation MUST behave as if OTEL_TRACES_SAMPLER_ARG is not set. | Known values for `OTEL_PROPAGATORS` are: From ca3dc24c1b95e7d285a559056e66f23f9e8df3ae Mon Sep 17 00:00:00 2001 From: Jack Berg Date: Wed, 18 Dec 2024 11:38:30 -0600 Subject: [PATCH 6/6] fix link --- specification/metrics/sdk_exporters/otlp.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/specification/metrics/sdk_exporters/otlp.md b/specification/metrics/sdk_exporters/otlp.md index 9c397648061..930d0b6e447 100644 --- a/specification/metrics/sdk_exporters/otlp.md +++ b/specification/metrics/sdk_exporters/otlp.md @@ -72,4 +72,4 @@ The recognized (case-insensitive) values for `OTEL_EXPORTER_OTLP_METRICS_DEFAULT - [OTEP0131 OTLP Exporters Configurable Export Behavior](https://github.com/open-telemetry/oteps/blob/main/text/metrics/0131-otlp-export-behavior.md) -[Enum]: ../configuration/sdk-environment-variables.md#enum +[Enum]: ../../configuration/sdk-environment-variables.md#enum