diff --git a/examples/kitchen-sink.yaml b/examples/kitchen-sink.yaml index 7ada259..e0100dc 100644 --- a/examples/kitchen-sink.yaml +++ b/examples/kitchen-sink.yaml @@ -41,12 +41,8 @@ logger_provider: max_export_batch_size: 512 # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: http/protobuf - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: endpoint: http://localhost:4318/v1/logs # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. @@ -72,7 +68,43 @@ logger_provider: # Configure max time (in milliseconds) to wait for each export. # If omitted or null, 10000 is used. timeout: 10000 - # Configure client transport security for the exporter's connection. Only applicable when .protocol is grpc and .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. + # Configure the encoding used for messages. Values include: protobuf, json. Implementations may not support json. + # If omitted or null, protobuf is used. + encoding: protobuf + - # Configure a batch log record processor. + batch: + # Configure exporter. + exporter: + # Configure exporter to be OTLP with gRPC transport. + otlp_grpc: + # Configure endpoint. + # If omitted or null, http://localhost:4317 is used. + endpoint: http://localhost:4317 + # Configure certificate. Absolute path to certificate file. + # If omitted or null, system default certificate verification is used for secure connections. + certificate: /app/cert.pem + # Configure mTLS private client key. Absolute path to client key in PEM format. If set, .client_certificate must also be set. + # If omitted or null, mTLS is not used. + client_key: /app/cert.pem + # Configure mTLS client certificate. Absolute path to certificate file. If set, .client_key must also be set. + # If omitted or null, mTLS is not used. + client_certificate: /app/cert.pem + # Configure headers. Entries have higher priority than entries from .headers_list. + # If an entry's .value is null, the entry is ignored. + headers: + - name: api-key + value: "1234" + # Configure headers. Entries have lower priority than entries from .headers. + # The value is a list of comma separated key-value pairs matching the format of OTEL_EXPORTER_OTLP_HEADERS. See https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/protocol/exporter.md#configuration-options for details. + # If omitted or null, no headers are added. + headers_list: "api-key=1234" + # Configure compression. Values include: gzip, none. Implementations may support other compression algorithms. + # If omitted or null, none is used. + compression: gzip + # Configure max time (in milliseconds) to wait for each export. + # If omitted or null, 10000 is used. + timeout: 10000 + # Configure client transport security for the exporter's connection. Only applicable when .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. # If omitted or null, false is used. insecure: false - # Configure a simple log record processor. @@ -145,12 +177,10 @@ meter_provider: timeout: 30000 # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: http/protobuf - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: + # Configure endpoint, including the metric specific path. + # If omitted or null, http://localhost:4318/v1/metrics is used. endpoint: http://localhost:4318/v1/metrics # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. @@ -176,9 +206,9 @@ meter_provider: # Configure max time (in milliseconds) to wait for each export. # If omitted or null, 10000 is used. timeout: 10000 - # Configure client transport security for the exporter's connection. Only applicable when .protocol is grpc and .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. - # If omitted or null, false is used. - insecure: false + # Configure the encoding used for messages. Values include: protobuf, json. Implementations may not support json. + # If omitted or null, protobuf is used. + encoding: protobuf # Configure temporality preference. Values include: cumulative, delta, low_memory. For behavior of values, see https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/sdk_exporters/otlp.md. # If omitted or null, cumulative is used. temporality_preference: delta @@ -189,6 +219,48 @@ meter_provider: producers: - # Configure metric producer to be prometheus. prometheus: + - # Configure a periodic metric reader. + periodic: + # Configure exporter. + exporter: + # Configure exporter to be OTLP with gRPC transport. + otlp_grpc: + # Configure endpoint. + # If omitted or null, http://localhost:4317 is used. + endpoint: http://localhost:4317 + # Configure certificate. Absolute path to certificate file. + # If omitted or null, system default certificate verification is used for secure connections. + certificate: /app/cert.pem + # Configure mTLS private client key. Absolute path to client key in PEM format. If set, .client_certificate must also be set. + # If omitted or null, mTLS is not used. + client_key: /app/cert.pem + # Configure mTLS client certificate. Absolute path to certificate file. If set, .client_key must also be set. + # If omitted or null, mTLS is not used. + client_certificate: /app/cert.pem + # Configure headers. Entries have higher priority than entries from .headers_list. + # If an entry's .value is null, the entry is ignored. + headers: + - name: api-key + value: "1234" + # Configure headers. Entries have lower priority than entries from .headers. + # The value is a list of comma separated key-value pairs matching the format of OTEL_EXPORTER_OTLP_HEADERS. See https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/protocol/exporter.md#configuration-options for details. + # If omitted or null, no headers are added. + headers_list: "api-key=1234" + # Configure compression. Values include: gzip, none. Implementations may support other compression algorithms. + # If omitted or null, none is used. + compression: gzip + # Configure max time (in milliseconds) to wait for each export. + # If omitted or null, 10000 is used. + timeout: 10000 + # Configure client transport security for the exporter's connection. Only applicable when .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. + # If omitted or null, false is used. + insecure: false + # Configure temporality preference. Values include: cumulative, delta, low_memory. For behavior of values, see https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/sdk_exporters/otlp.md. + # If omitted or null, cumulative is used. + temporality_preference: delta + # Configure default histogram aggregation. Values include: explicit_bucket_histogram, base2_exponential_bucket_histogram. For behavior of values, see https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/sdk_exporters/otlp.md. + # If omitted or null, explicit_bucket_histogram is used. + default_histogram_aggregation: base2_exponential_bucket_histogram - # Configure a periodic metric reader. periodic: # Configure exporter. @@ -293,12 +365,10 @@ tracer_provider: max_export_batch_size: 512 # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: http/protobuf - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: + # Configure endpoint, including the trace specific path. + # If omitted or null, http://localhost:4318/v1/traces is used. endpoint: http://localhost:4318/v1/traces # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. @@ -324,7 +394,43 @@ tracer_provider: # Configure max time (in milliseconds) to wait for each export. # If omitted or null, 10000 is used. timeout: 10000 - # Configure client transport security for the exporter's connection. Only applicable when .protocol is grpc and .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. + # Configure the encoding used for messages. Values include: protobuf, json. Implementations may not support json. + # If omitted or null, protobuf is used. + encoding: protobuf + - # Configure a batch span processor. + batch: + # Configure exporter. + exporter: + # Configure exporter to be OTLP with gRPC transport. + otlp_grpc: + # Configure endpoint. + # If omitted or null, http://localhost:4317 is used. + endpoint: http://localhost:4317 + # Configure certificate. Absolute path to certificate file. + # If omitted or null, system default certificate verification is used for secure connections. + certificate: /app/cert.pem + # Configure mTLS private client key. Absolute path to client key in PEM format. If set, .client_certificate must also be set. + # If omitted or null, mTLS is not used. + client_key: /app/cert.pem + # Configure mTLS client certificate. Absolute path to certificate file. If set, .client_key must also be set. + # If omitted or null, mTLS is not used. + client_certificate: /app/cert.pem + # Configure headers. Entries have higher priority than entries from .headers_list. + # If an entry's .value is null, the entry is ignored. + headers: + - name: api-key + value: "1234" + # Configure headers. Entries have lower priority than entries from .headers. + # The value is a list of comma separated key-value pairs matching the format of OTEL_EXPORTER_OTLP_HEADERS. See https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/protocol/exporter.md#configuration-options for details. + # If omitted or null, no headers are added. + headers_list: "api-key=1234" + # Configure compression. Values include: gzip, none. Implementations may support other compression algorithms. + # If omitted or null, none is used. + compression: gzip + # Configure max time (in milliseconds) to wait for each export. + # If omitted or null, 10000 is used. + timeout: 10000 + # Configure client transport security for the exporter's connection. Only applicable when .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. # If omitted or null, false is used. insecure: false - # Configure a batch span processor. diff --git a/examples/sdk-config.yaml b/examples/sdk-config.yaml index 7c4824d..41ff4c3 100644 --- a/examples/sdk-config.yaml +++ b/examples/sdk-config.yaml @@ -55,12 +55,10 @@ tracer_provider: max_export_batch_size: 512 # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: http/protobuf - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: + # Configure endpoint, including the trace specific path. + # If omitted or null, http://localhost:4318/v1/traces is used. endpoint: http://localhost:4318/v1/traces # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. @@ -145,12 +143,10 @@ meter_provider: timeout: 30000 # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: http/protobuf - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: + # Configure endpoint, including the metric specific path. + # If omitted or null, http://localhost:4318/v1/metrics is used. endpoint: http://localhost:4318/v1/metrics # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. @@ -200,12 +196,8 @@ logger_provider: max_export_batch_size: 512 # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: http/protobuf - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: endpoint: http://localhost:4318/v1/logs # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. diff --git a/examples/sdk-migration-config.yaml b/examples/sdk-migration-config.yaml index 66d9402..9b46533 100644 --- a/examples/sdk-migration-config.yaml +++ b/examples/sdk-migration-config.yaml @@ -25,7 +25,7 @@ # - OTEL_TRACES_EXPORTER # - OTEL_METRICS_EXPORTER # - OTEL_LOGS_EXPORTER -# - OTEL_EXPORTER_OTLP_PROTOCOL +# - OTEL_EXPORTER_OTLP_PROTOCOL, OTEL_EXPORTER_OTLP_{SIGNAL}_PROTOCOL # - OTEL_EXPORTER_OTLP_ENDPOINT # - OTEL_EXPORTER_OTLP_INSECURE, OTEL_EXPORTER_OTLP_{SIGNAL}_INSECURE # - OTEL_EXPORTER_OTLP_CERTIFICATE @@ -88,12 +88,10 @@ tracer_provider: max_export_batch_size: ${OTEL_BSP_MAX_EXPORT_BATCH_SIZE:-512} # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: ${OTEL_EXPORTER_OTLP_TRACES_PROTOCOL:-http/protobuf} - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: + # Configure endpoint, including the trace specific path. + # If omitted or null, http://localhost:4318/v1/traces is used. endpoint: ${OTEL_EXPORTER_OTLP_TRACES_ENDPOINT:-http://localhost:4318/v1/traces} # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. @@ -184,12 +182,10 @@ meter_provider: timeout: ${OTEL_METRIC_EXPORT_TIMEOUT:-30000} # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: ${OTEL_EXPORTER_OTLP_METRICS_PROTOCOL:-http/protobuf} - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: + # Configure endpoint, including the metric specific path. + # If omitted or null, http://localhost:4318/v1/metrics is used. endpoint: ${OTEL_EXPORTER_OTLP_METRICS_ENDPOINT:-http://localhost:4318/v1/metrics} # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. @@ -243,12 +239,8 @@ logger_provider: max_export_batch_size: ${OTEL_BLRP_MAX_EXPORT_BATCH_SIZE:-512} # Configure exporter. exporter: - # Configure exporter to be OTLP. - otlp: - # Configure protocol. Values include: http/protobuf, http/json, grpc. - protocol: ${OTEL_EXPORTER_OTLP_LOGS_PROTOCOL:-http/protobuf} - # Configure endpoint. - # If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). + # Configure exporter to be OTLP with HTTP transport. + otlp_http: endpoint: ${OTEL_EXPORTER_OTLP_LOGS_ENDPOINT:-http://localhost:4318/v1/logs} # Configure certificate. Absolute path to certificate file. # If omitted or null, system default certificate verification is used for secure connections. diff --git a/schema/common.json b/schema/common.json index fe1b8fd..6ee683f 100644 --- a/schema/common.json +++ b/schema/common.json @@ -36,16 +36,55 @@ "name", "value" ] }, - "Otlp": { - "type": "object", + "OtlpHttpExporter": { + "title": "OtlpHttpExporter", + "type": ["object", "null"], "additionalProperties": false, "properties": { - "protocol": { - "type": "string", - "pattern": "^(http|grpc)\\/(protobuf|json)" + "endpoint": { + "type": ["string", "null"] + }, + "certificate": { + "type": ["string", "null"] + }, + "client_key": { + "type": ["string", "null"] + }, + "client_certificate": { + "type": ["string", "null"] + }, + "headers": { + "type": "array", + "items": { + "$ref": "common.json#/$defs/NameStringValuePair" + } + }, + "headers_list": { + "type": ["string", "null"] + }, + "compression": { + "type": ["string", "null"] }, + "timeout": { + "type": ["integer", "null"], + "minimum": 0 + }, + "encoding": { + "type": ["string", "null"], + "enum": [ + "protobuf", + "json" + ] + } + } + }, + "OtlpGrpcExporter": { + "title": "OtlpGrpcExporter", + "type": ["object", "null"], + "additionalProperties": false, + "properties": { "endpoint": { - "type": "string" + "type": ["string", "null"] }, "certificate": { "type": ["string", "null"] @@ -75,14 +114,9 @@ "insecure": { "type": ["boolean", "null"] } - }, - "required": [ - "endpoint", - "protocol" - ], - "title": "Otlp" + } }, - "Console": { + "ConsoleExporter": { "type": ["object", "null"], "additionalProperties": false } diff --git a/schema/logger_provider.json b/schema/logger_provider.json index afbcc8f..52f6bf0 100644 --- a/schema/logger_provider.json +++ b/schema/logger_provider.json @@ -65,11 +65,14 @@ "minProperties": 1, "maxProperties": 1, "properties": { - "otlp": { - "$ref": "common.json#/$defs/Otlp" + "otlp_http": { + "$ref": "common.json#/$defs/OtlpHttpExporter" + }, + "otlp_grpc": { + "$ref": "common.json#/$defs/OtlpGrpcExporter" }, "console": { - "$ref": "common.json#/$defs/Console" + "$ref": "common.json#/$defs/ConsoleExporter" } }, "patternProperties": { diff --git a/schema/meter_provider.json b/schema/meter_provider.json index 996b9e2..5dd33ad 100644 --- a/schema/meter_provider.json +++ b/schema/meter_provider.json @@ -82,11 +82,14 @@ "minProperties": 1, "maxProperties": 1, "properties": { - "otlp": { - "$ref": "#/$defs/OtlpMetric" + "otlp_http": { + "$ref": "#/$defs/OtlpHttpMetricExporter" + }, + "otlp_grpc": { + "$ref": "#/$defs/OtlpGrpcMetricExporter" }, "console": { - "$ref": "common.json#/$defs/Console" + "$ref": "common.json#/$defs/ConsoleExporter" } }, "patternProperties": { @@ -102,7 +105,7 @@ "maxProperties": 1, "properties": { "prometheus": { - "$ref": "#/$defs/Prometheus" + "$ref": "#/$defs/PrometheusMetricExporter" } }, "patternProperties": { @@ -128,7 +131,8 @@ } } }, - "Prometheus": { + "PrometheusMetricExporter": { + "title": "PrometheusMetricExporter", "type": ["object", "null"], "additionalProperties": false, "properties": { @@ -166,16 +170,30 @@ } } }, - "OtlpMetric": { - "type": "object", + "ExporterTemporalityPreference": { + "title": "ExporterTemporalityPreference", + "type": ["string", "null"], + "enum": [ + "cumulative", + "delta", + "low_memory" + ] + }, + "ExporterDefaultHistogramAggregation": { + "title": "ExporterDefaultHistogramAggregation", + "type": ["string", "null"], + "enum": [ + "explicit_bucket_histogram", + "base2_exponential_bucket_histogram" + ] + }, + "OtlpHttpMetricExporter": { + "title": "OtlpHttpMetricExporter", + "type": ["object", "null"], "additionalProperties": false, "properties": { - "protocol": { - "type": "string", - "pattern": "^(http|grpc)\\/(protobuf|json)" - }, "endpoint": { - "type": "string" + "type": ["string", "null"] }, "certificate": { "type": ["string", "null"] @@ -202,30 +220,64 @@ "type": ["integer", "null"], "minimum": 0 }, - "temporality_preference": { + "encoding": { "type": ["string", "null"], "enum": [ - "cumulative", - "delta", - "low_memory" + "protobuf", + "json" ] }, + "temporality_preference": { + "$ref": "#/$defs/ExporterTemporalityPreference" + }, "default_histogram_aggregation": { - "type": ["string", "null"], - "enum": [ - "explicit_bucket_histogram", - "base2_exponential_bucket_histogram" - ] + "$ref": "#/$defs/ExporterDefaultHistogramAggregation" + } + } + }, + "OtlpGrpcMetricExporter": { + "title": "OtlpGrpcMetricExporter", + "type": ["object", "null"], + "additionalProperties": false, + "properties": { + "endpoint": { + "type": ["string", "null"] + }, + "certificate": { + "type": ["string", "null"] + }, + "client_key": { + "type": ["string", "null"] + }, + "client_certificate": { + "type": ["string", "null"] + }, + "headers": { + "type": "array", + "items": { + "$ref": "common.json#/$defs/NameStringValuePair" + } + }, + "headers_list": { + "type": ["string", "null"] + }, + "compression": { + "type": ["string", "null"] + }, + "timeout": { + "type": ["integer", "null"], + "minimum": 0 }, "insecure": { "type": ["boolean", "null"] + }, + "temporality_preference": { + "$ref": "#/$defs/ExporterTemporalityPreference" + }, + "default_histogram_aggregation": { + "$ref": "#/$defs/ExporterDefaultHistogramAggregation" } - }, - "required": [ - "endpoint", - "protocol" - ], - "title": "OtlpMetric" + } }, "View": { "type": "object", diff --git a/schema/tracer_provider.json b/schema/tracer_provider.json index 6e96886..1471278 100644 --- a/schema/tracer_provider.json +++ b/schema/tracer_provider.json @@ -137,14 +137,17 @@ "minProperties": 1, "maxProperties": 1, "properties": { - "otlp": { - "$ref": "common.json#/$defs/Otlp" + "otlp_http": { + "$ref": "common.json#/$defs/OtlpHttpExporter" + }, + "otlp_grpc": { + "$ref": "common.json#/$defs/OtlpGrpcExporter" }, "console": { - "$ref": "common.json#/$defs/Console" + "$ref": "common.json#/$defs/ConsoleExporter" }, "zipkin": { - "$ref": "#/$defs/Zipkin" + "$ref": "#/$defs/ZipkinSpanExporter" } }, "patternProperties": { @@ -202,7 +205,8 @@ } } }, - "Zipkin": { + "ZipkinSpanExporter": { + "title": "ZipkinSpanExporter", "type": ["object", "null"], "additionalProperties": false, "properties": { @@ -213,8 +217,7 @@ "type": ["integer", "null"], "minimum": 0 } - }, - "title": "Zipkin" + } } } } diff --git a/schema/type_descriptions.yaml b/schema/type_descriptions.yaml index 01131b2..f068da1 100644 --- a/schema/type_descriptions.yaml +++ b/schema/type_descriptions.yaml @@ -161,7 +161,8 @@ - type: LogRecordExporter property_descriptions: - otlp: Configure exporter to be OTLP. + otlp_http: Configure exporter to be OTLP with HTTP transport. + otlp_grpc: Configure exporter to be OTLP with gRPC transport. console: Configure exporter to be console. path_patterns: - .logger_provider.processors[].*.exporter @@ -229,13 +230,14 @@ - type: SpanExporter property_descriptions: - otlp: Configure exporter to be OTLP. + otlp_http: Configure exporter to be OTLP with HTTP transport. + otlp_grpc: Configure exporter to be OTLP with gRPC transport. zipkin: Configure exporter to be zipkin. console: Configure exporter to be console. path_patterns: - .tracer_provider.processors[].*.exporter -- type: Zipkin +- type: ZipkinSpanExporter property_descriptions: endpoint: > Configure endpoint. @@ -364,12 +366,13 @@ - type: MetricExporter property_descriptions: prometheus: Configure exporter to be prometheus. - otlp: Configure exporter to be OTLP. + otlp_http: Configure exporter to be OTLP with HTTP transport. + otlp_grpc: Configure exporter to be OTLP with gRPC transport. console: Configure exporter to be console. path_patterns: - .meter_provider.readers[].*.exporter -- type: Prometheus +- type: PrometheusMetricExporter property_descriptions: host: > Configure host. @@ -502,14 +505,8 @@ # END meter_provider # START common -- type: Otlp +- type: OtlpExporterCommon property_descriptions: - protocol: > - Configure protocol. Values include: http/protobuf, http/json, grpc. - endpoint: > - Configure endpoint. - - If .protocol is http/protobuf or http/json, the signal specific path must be included (i.e. http://localhost:4318/v1/{signal}). If .protocol is grpc, a path should not be included (i.e. http://localhost:4317). certificate: > Configure certificate. Absolute path to certificate file. @@ -540,10 +537,6 @@ Configure max time (in milliseconds) to wait for each export. If omitted or null, 10000 is used. - insecure: > - Configure client transport security for the exporter's connection. Only applicable when .protocol is grpc and .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. - - If omitted or null, false is used. temporality_preference: > Configure temporality preference. Values include: cumulative, delta, low_memory. For behavior of values, see https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/sdk_exporters/otlp.md. @@ -553,9 +546,60 @@ If omitted or null, explicit_bucket_histogram is used. path_patterns: - - .tracer_provider.processors[].*.exporter.otlp - - .logger_provider.processors[].*.exporter.otlp - - .meter_provider.readers[].periodic.exporter.otlp + - .tracer_provider.processors[].*.exporter.otlp_http + - .logger_provider.processors[].*.exporter.otlp_http + - .meter_provider.readers[].periodic.exporter.otlp_http + - .tracer_provider.processors[].*.exporter.otlp_grpc + - .logger_provider.processors[].*.exporter.otlp_grpc + - .meter_provider.readers[].periodic.exporter.otlp_grpc +- type: OtlpHttpExporter + property_descriptions: + encoding: > + Configure the encoding used for messages. Values include: protobuf, json. Implementations may not support json. + + If omitted or null, protobuf is used. + path_patterns: + - .tracer_provider.processors[].*.exporter.otlp_http + - .logger_provider.processors[].*.exporter.otlp_http + - .meter_provider.readers[].periodic.exporter.otlp_http +- type: OtlpHttpSpanExporter + property_descriptions: + endpoint: > + Configure endpoint, including the trace specific path. + + If omitted or null, http://localhost:4318/v1/traces is used. + path_patterns: + - .tracer_provider.processors[].*.exporter.otlp_http +- type: OtlpHttpMetricExporter + property_descriptions: + endpoint: > + Configure endpoint, including the metric specific path. + + If omitted or null, http://localhost:4318/v1/metrics is used. + path_patterns: + - .meter_provider.readers[].periodic.exporter.otlp_http +- type: OtlpHttpLogRecordExporter + property_descriptions: + endpoint: > + Configure endpoint, including the log specific path. + + If omitted or null, http://localhost:4318/v1/logs is used. + path_patterns: + - .meter_provider.readers[].periodic.exporter.otlp_http +- type: OtlpGrpcExporter + property_descriptions: + endpoint: > + Configure endpoint. + + If omitted or null, http://localhost:4317 is used. + insecure: > + Configure client transport security for the exporter's connection. Only applicable when .endpoint is provided without http or https scheme. Implementations may choose to ignore .insecure. + + If omitted or null, false is used. + path_patterns: + - .tracer_provider.processors[].*.exporter.otlp_grpc + - .logger_provider.processors[].*.exporter.otlp_grpc + - .meter_provider.readers[].periodic.exporter.otlp_grpc # END common # START Instrumentation diff --git a/scripts/generate-descriptions.js b/scripts/generate-descriptions.js index 6dc47d2..2564f9f 100644 --- a/scripts/generate-descriptions.js +++ b/scripts/generate-descriptions.js @@ -80,13 +80,16 @@ yaml.visit(fileDoc, { debug("parentPath: " + parentPath ); debug("propertyKey: " + propertyKey); debug("currentNodePath: " + parentPath + (parentPath === "." ? "" : ".") + propertyKey); - // Iterate through the rules and find the first with a matching entry in rule.path_patterns + // Iterate through the rules and find the first with a matching entry in rule.path_patterns and with defined property key const matchingRule = typeDescriptionsYaml.find((rule) => { const matchingPathPattern = rule['path_patterns'].find((pathPattern) => { const regex = new RegExp(toRegex(pathPattern)); return regex.test(parentPath); }); - return matchingPathPattern !== undefined; + if (matchingPathPattern === undefined) { + return false; + } + return rule['property_descriptions'][propertyKey] !== undefined; }); // Exit early if no matching rule if (matchingRule === undefined) { @@ -94,13 +97,8 @@ yaml.visit(fileDoc, { return; } debug("matched rule: " + matchingRule.type); - // Check if there is a description for the current propertyKey in the matching rule - // Exit early if none registered + // We already guarantee that the propertyKey is defined for the rule above const description = matchingRule['property_descriptions'][propertyKey]; - if (description === undefined) { - debug("no matching property") - return; - } // Format the description let formattedDescription = description.replace(/\n$/, '').split('\n').map(line => ' ' + line).join('\n'); // If we're on the first element, prefix the formatted description with the existing commentBefore to retain the comments at the top of the file