-
Notifications
You must be signed in to change notification settings - Fork 4.8k
Commit
This PR adds an OTLP logger to Envoy, which allows users to flexibly configure their log structure (according to OpenTelemetry protos). The API users the common gRPC configuration, used in ALS, for gRPC settings. The flexible OT fields (body, attributes) are completely configurable and are filled with request/response information based on Envoy access log formatting. There are still a couple of TODOs - The 'filter_state_objects_to_log' from the common gRPC config isn't added to the log Resource attributes are not configurable, and only Envoy node info is added. Note: this extension was added as v3alpha API. Risk Level: Low - a new extension, so unlikely to break any existing setups (marked as v3alpha API). Testing: Unit tests. Docs Changes: Release Notes: access log: added a new :ref:OpenTelemetry access logger <envoy_v3_api_msg_extensions.access_loggers.open_telemetry.v3alpha.OpenTelemetryAccessLogConfig> extension, allowing a flexible log structure with native Envoy access log formatting. Signed-off-by: Itamar Kaminski <[email protected]>
- Loading branch information
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# DO NOT EDIT. This file is generated by tools/proto_format/proto_sync.py. | ||
|
||
load("@envoy_api//bazel:api_build_system.bzl", "api_proto_package") | ||
|
||
licenses(["notice"]) # Apache 2 | ||
|
||
api_proto_package( | ||
deps = [ | ||
"//envoy/extensions/access_loggers/grpc/v3:pkg", | ||
"@com_github_cncf_udpa//udpa/annotations:pkg", | ||
"@opentelemetry_proto//:logs", | ||
], | ||
) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
syntax = "proto3"; | ||
|
||
package envoy.extensions.access_loggers.open_telemetry.v3alpha; | ||
|
||
import "envoy/extensions/access_loggers/grpc/v3/als.proto"; | ||
|
||
import "opentelemetry/proto/common/v1/common.proto"; | ||
|
||
import "udpa/annotations/status.proto"; | ||
import "validate/validate.proto"; | ||
|
||
option java_package = "io.envoyproxy.envoy.extensions.access_loggers.open_telemetry.v3alpha"; | ||
option java_outer_classname = "LogsServiceProto"; | ||
option java_multiple_files = true; | ||
option (udpa.annotations.file_status).work_in_progress = true; | ||
option (udpa.annotations.file_status).package_version_status = ACTIVE; | ||
|
||
// [#protodoc-title: OpenTelemetry (gRPC) Access Log] | ||
|
||
// Configuration for the built-in *envoy.access_loggers.open_telemetry* | ||
// :ref:`AccessLog <envoy_api_msg_config.accesslog.v3.AccessLog>`. This configuration will | ||
// populate `opentelemetry.proto.collector.v1.logs.ExportLogsServiceRequest.resource_logs <https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/collector/logs/v1/logs_service.proto>`_. | ||
// OpenTelemetry `Resource <https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/resource/v1/resource.proto>`_ | ||
// attributes are filled with Envoy node info. In addition, the request start time is set in the | ||
// dedicated field. | ||
// [#extension: envoy.access_loggers.open_telemetry] | ||
// [#comment:TODO(itamarkam): allow configuration for resource attributes.] | ||
message OpenTelemetryAccessLogConfig { | ||
// [#comment:TODO(itamarkam): add 'filter_state_objects_to_log' to logs.] | ||
grpc.v3.CommonGrpcAccessLogConfig common_config = 1 [(validate.rules).message = {required: true}]; | ||
|
||
// OpenTelemetry `LogResource <https://github.com/open-telemetry/opentelemetry-proto/blob/main/opentelemetry/proto/logs/v1/logs.proto>`_ | ||
// fields, following `Envoy access logging formatting <https://www.envoyproxy.io/docs/envoy/latest/configuration/observability/access_log/usage>`_. | ||
// | ||
// See 'body' in the LogResource proto for more details. | ||
// Example: ``body { string_value: "%PROTOCOL%" }``. | ||
opentelemetry.proto.common.v1.AnyValue body = 2; | ||
|
||
// See 'attributes' in the LogResource proto for more details. | ||
// Example: ``attributes { values { key: "user_agent" value { string_value: "%REQ(USER-AGENT)%" } } }``. | ||
opentelemetry.proto.common.v1.KeyValueList attributes = 3; | ||
} |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,3 +9,4 @@ Access loggers | |
|
||
v3/* | ||
../../extensions/access_loggers/*/v3/* | ||
../../extensions/access_loggers/*/v3alpha/* |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.