Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add compression configuration to the OpenTelemetry Environment Variable Specification #2852

Closed
Donnerbart opened this issue Oct 4, 2022 · 3 comments
Assignees
Labels
area:configuration Related to configuring the SDK [label deprecated] triaged-needmoreinfo [label deprecated] The issue is triaged - the OTel community needs more information to decide spec:miscellaneous For issues that don't match any other spec label

Comments

@Donnerbart
Copy link

Donnerbart commented Oct 4, 2022

What are you trying to achieve?

I would like to add missing environment variables to configure compression on (span) exporters to the OpenTelemetry Environment Variable Specification and clarify the compression default value for the OTLP exporter on OpenTelemetry Protocol Exporter.

The suggested new environment variables are:

  • OTEL_EXPORTER_JAEGER_COMPRESSION: The compression type to use on Jaeger trace requests. Options include none and gzip. Default is none.
  • OTEL_EXPORTER_ZIPKIN_COMPRESSION: The compression type to use on Zipkin trace requests. Options include none and gzip. Default is gzip.

The environment variables to clarify are:

  • OTEL_EXPORTER_OTLP_COMPRESSION, OTEL_EXPORTER_OTLP_TRACES_COMPRESSION, OTEL_EXPORTER_OTLP_METRICS_COMPRESSION, OTEL_EXPORTER_OTLP_LOGS_COMPRESSION: The compression type to use on OTLP log requests. Options include none and gzip. Default is none.

The default values are taken from the current implementation of the OpenTelemetry Java SDK.

EDIT: Please notice that in Java compression is currently disabled by default for OTLP and Jaeger, but enabled for Zipkin (using gzip). This may overlap with existing issues like #2098 and #1895.

Additional context.

As a user of the OpenTelemetry Java SDK I'd like to be able to configure compression consistently over the provided trace/metric/log exporters. For the OTLP exporters there is already a programmatic way to configure compression, for Jaeger and Zipkin I'm working on a contribution to add those to the SDK. During the review I was made aware, that for auto-configuration we need to add new environment variables to the SDK specification.

@Donnerbart Donnerbart added the spec:miscellaneous For issues that don't match any other spec label label Oct 4, 2022
@joaopgrassi joaopgrassi added the area:configuration Related to configuring the SDK label Oct 4, 2022
@reyang reyang added the [label deprecated] triaged-needmoreinfo [label deprecated] The issue is triaged - the OTel community needs more information to decide label Oct 7, 2022
@reyang
Copy link
Member

reyang commented Oct 7, 2022

@Donnerbart during the triage meeting, we have question regarding why these new environment variables are needed, and why the defaults are different. It'll be helpful if folks could comment here providing examples in their usage scenario. We also encourage you to join the weekly specification SIG meeting (on Tue.) to discuss this further.

CC @yurishkuro regarding the default compression for Jaeger.

@Donnerbart
Copy link
Author

@reyang A big motivation is feature parity between the exporters provided by OpenTelemetry. The OTLP exporters already offers compression configuration, and at least for Java the underlying Jaeger and Zipkin exporters also have compression capabilities.

In general I think it's useful to make the compression configurable, since there might be use cases where network is the bigger bottleneck than CPU, even for local transportation. For example, my company provides an MQTT broker with millions of connected clients. The network can be very easily saturated, while there is still CPU available. So we would like to be able to offer this configuration for our customers, to balance network vs. CPU usage in production systems.

I think it's also helpful to define the default values in the specification, since at in the OTel Java SDK we discovered that the Zipkin exporter (gzip is enabled) uses a different default than OTel and Jaeger (no compression is enabled). I have no idea how this looks in other implementations though.

@Donnerbart
Copy link
Author

Donnerbart commented Oct 11, 2022

Results from the SIG discussion:

  • The wording for the OTLP default value is deliberately "no value" (after long discussions), so the implementations can decide what's the best for their use case. So there is nothing to do here.
  • The future of Jaeger is still to be decided. Until then we should probably not add more configuration options.

So what's left would be to specify a new environment variable for Zipkin to make the compression configurable, specify the valid values (none and gzip) and leave the default to the implementations (like with OTLP).

Since our use-case is fully satisfied with the programmatic API of the Java SDK, I'm happy with every outcome of this issue.

@Donnerbart Donnerbart closed this as not planned Won't fix, can't repro, duplicate, stale Oct 10, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area:configuration Related to configuring the SDK [label deprecated] triaged-needmoreinfo [label deprecated] The issue is triaged - the OTel community needs more information to decide spec:miscellaneous For issues that don't match any other spec label
Projects
None yet
Development

No branches or pull requests

4 participants