Releases: open-telemetry/opentelemetry-java
Version 1.36.0
SDK
Traces
- Lazily initialize the container for events in the SDK Span implementation (#6244)
Exporters
- Add basic proxy configuration to OtlpHttp{Signal}Exporters (#6270)
- Add connectTimeout configuration option OtlpGrpc{Signal}Exporters (#6079)
Extensions
- Add ComponentLoader to autoconfigure support more scenarios (#6217)
- Added MetricReader customizer for AutoConfiguredOpenTelemetrySdkBuilder (#6231)
- Return AutoConfiguredOpenTelemetrySdkBuilder instead of the base type (#6248)
Tooling
- Add note about draft PRs to CONTRIBUTING.md (#6247)
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@alexandru-roman-db
@asafm
@breedx-splk
@jack-berg
@jeanbisutti
@jkwatson
@johnbley
@lmolkova
@marcschumacher
@trask
@tydhot
@zeitlinger
Version 1.35.0
NOTE: The opentelemetry-exporter-jaeger
and opentelemetry-exporter-jaeger-thift
artifacts have stopped being published. Jaeger has native support for OTLP, and users should export to jaeger using OTLP instead.
API
Incubator
- Add Span#addLink, for adding a link after span start (#6084)
SDK
Traces
- Bugfix: Ensure span status cannot be updated after set to StatusCode.OK (#6209
Metrics
- Reusable memory Mode: Adding support for exponential histogram aggregation (#6058, #6136)
- Reusable memory mode: Adding support for explicit histogram aggregation (#6153)
- Reusable memory mode: Adding support for sum aggregation (#6182)
- Reusable memory mode: Adding support for last value aggregation (#6196)
Exporters
- Recreate / fix graal issue detecting RetryPolicy class (#6139, #6134)
- Restore prometheus metric name mapper tests, fix regressions (#6138)
- WARNING: Remove jaeger exporters (#6119)
- Update dependency
io.zipkin.reporter2:zipkin-reporter-bom
to 3.2.1. Note:ZipkinSpanExporterBuilder#setEncoder(zipkin2.codec.BytesEncoder)
has been deprecated in favor ofZipkinSpanExporterBuilder#setEncoder(zipkin2.reporter.BytesEncoder)
.ZipkinSpanExporterBuilder#setSender(zipkin2.reporter.Sender)
has been deprecated in favor ofZipkinSpanExporterBuilder#setSender(zipkin2.reporter.BytesMessageSender)
. (#6129, #6151) - Include trace flags in otlp marshaller (#6167)
- Add Compressor SPI support to OtlpGrpc{Signal}Exporters (#6103)
- Allow Prometheus exporter to add resource attributes to metric attributes (#6179)
Extension
- Autoconfigure accepts encoded header values for OTLP exporters (#6164)
Incubator
- Align file configuration with latest changes to spec (#6088)
Tooling
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@apederson94
@asafm
@breedx-splk
@brunobat
@codefromthecrypt
@fstab
@jack-berg
@jkwatson
@NicklasWallgren
@patrick-me
@psx95
@trask
@zeitlinger
Version 1.34.1
Version 1.34.0
NOTE: This is the LAST release for opentelemetry-exporter-jaeger
and opentelemetry-exporter-jaeger-thift
. Jaeger has native support for OTLP, and users should export to jaeger using OTLP instead.
API
- Ability to access version.properties API file with GraalVM native (#6095)
SDK
Traces
- Only call SpanProcessor onStart / onEnd if required (#6112)
- Add option to export unsampled spans from span processors (#6057)
Metrics
- Memory Mode: Adding first part support for synchronous instruments - storage (#5998)
- Base2ExponentialHistogramAggregation maxBuckets must be >= 2 (#6093)
- Convert histogram measurements to double before passing recording exemplar reservoir (#6024)
Exporters
- Add compressor SPI to support additional compression algos (#5990)
- Test OTLP exporters with different OkHttp versions (#6045)
- Refactor prometheus exporter to use
io.prometheus:prometheus-metrics-exporter-httpserver
, add exponential Histogram support (#6015) - UpstreamGrpcSenderProvider uses minimal fallback managed channel when none is specified (#6110)
- OTLP exporters propagate serialization IOException instead of rethrowing as runtime (#6082)
Extensions
- Autoconfigure reads normalized otel.config.file property (#6105)
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@asafm
@axw
@fax4ever
@fstab
@HaloFour
@jack-berg
@jeanbisutti
@jkwatson
@lchdev
@nluk
@NthPortal
@patrick-me
@ricardo-mestre
@TomasChladekSL
@trask
Version 1.33.0
API
- Fix issue where wrapping "invalid" SpanContexts in Span does not preserve SpanContext (#6044)
Incubator
- Refactor and add to ExtendedTracer, add ExtendedContextPropagators (#6017)
- Base64 encode AnyValue bytes in string representation (#6003)
SDK
Exporters
- Add connectTimeout configuration option OtlpHttp{Signal}Exporters (#5941)
- Add ability for Otlp{Protocol}LogRecordExporter to serialize log body any value (#5938)
- Android environments can now handle base64 encoded PEM keys, remove exception handling in TlsUtil#decodePem (#6034)
- Add header supplier configuration option to OTLP exporters (#6004)
Extensions
- Add autoconfigure option for customizing SpanProcessor, LogRecordProcessor (#5986)
- Incubator allows for simpler creation of start-only and end-only SpanProcessors. (#5923)
Testing
- Add hasAttributesSatisfying overload to AbstractPointAssert (#6048)
Project Tooling
- Building animal sniffer signatures directly from android corelib (#5973)
- Target kotlin 1.6 in kotlin extension (#5910)
- Define language version compatibility requirements (#5983)
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@anuraaga
@asafm
@breedx-splk
@chungngoops
@felixscheinost
@jack-berg
@jackshirazi
@jkwatson
@JonasKunz
@laurit
@LikeTheSalad
@mateuszrzeszutek
@mikelaspina
@PeterF778
@scheler
@SenNeonoveNoci
@shadow0wolf
@trask
@zeitlinger
Version 1.32.0
API
- Stabilize explicit bucket boundaries advice API (#5897)
- Allow events to be emitted with timestamp (#5928)
Context
- Add null check to StrictContextStorage (#5954)
Incubator
- Experimental support for Log AnyValue body (#5880)
SDK
Metrics
- Dismantle AbstractInstrumentBuilder inheritance hierarchy (#5820)
- Fix delta metric storage concurrency bug that allows for lost writes when record operations occur during collection. The fix introduces additional work on record threads to ensure correctness. The additional overhead is non-blocking and should be small according to performance testing. Still, there may be an opportunity for further optimization. (#5932, #5976)
Exporters
- Prometheus exporter: omit empty otel_scope_info and otel_target_info metrics (#5887)
- JdkHttpSender should retry on connect exceptions (#5867)
- Expand the set of retryable exceptions in JdkHttpSender (#5942)
- Identify OTLP export calls with context key used for instrumentation suppression (#5918)
Testing
- Add log support to junit extensions (#5966)
SDK Extensions
- Add file configuration to autoconfigure (#5831)
- Update to file configuration to use opentelemetry-configuration v0.1.0 (#5899)
- Add env var substitution support to file configuration (#5914)
- Stop setting Resource schemaUrl in autoconfigure (#5911)
- Add AutoConfigureListener to provide components with autoconfigured SDK (#5931)
OpenCensus Shim
- Clean up OpenCensus shim (#5858)
OpenTracing Shim
- Fix OpenTracing header name issue (#5840)
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@abdolsamad
@anuraaga
@asafm
@breedx-splk
@dashpole
@jack-berg
@jackshirazi
@jamesylgan
@jkwatson
@laurit
@LikeTheSalad
@mateuszrzeszutek
@mikelaspina
@nluk
@steffan-westcott
@trask
Version 1.31.0
API
Incubator
- Refactor advice API to simplify usage (#5848)
SDK
- BatchLogRecordProcessor and BatchSpanProcessor unify
queueSize
metric description and attribute name forprocessorType
(#5836)
Metrics
- Allow instrument names to contain a forward slash (#5824)
- Memory Mode support: Adding memory mode, and implementing it for Asynchronous Instruments (#5709, #5855)
- Stabilize MetricProducer, allow custom MetricReaders (#5835)
- Drop NaN measurements to metric instruments (#5859)
- Fix flaky MetricExporterConfigurationTest (#5877)
Logs
- Add addAllAttributes() to ReadWriteLogRecord. (#5825)
Exporters
- Prometheus exporter: handle colliding metric attribute keys (#5717)
SDK Extensions
- File configuration ConfigurationReader handles null values as empty (#5829)
Semantic conventions
- BREAKING: Stop publishing
io.opentelemetry:opentelemetry-semconv
. Please useio.opentelemetry.semconv:opentelemetry-semconv:1.21.0-alpha
instead, which is published from open-telemetry/semantic-conventions-java. The new repository is published in lockstep with open-telemetry/semantic-conventions. (#5807)
Project Tooling
- Add Benchmark workflows (#5842, #5874)
- Add clearer docs around coroutine support with an example (#5799)
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@aabmass
@asafm
@breedx-splk
@cbos
@cmunger
@dashpole
@evantorrie
@jack-berg
@jkwatson
@laurit
@LikeTheSalad
@mateuszrzeszutek
@puckpuck
@scprek
@trask
@tylerbenson
Version 1.30.1
This is a patch release on the previous 1.30.0 release, fixing the issue(s) below.
- Fix autoconfigure bug creating multiple
PrometheusHttpServer
instances with same port (#5911)
Version 1.30.0
API
Incubator
- Add experimental synchronous gauge (#5506)
SDK
Metrics
- Add attributes advice API (#5677, #5722)
- Add AttributesProcessor toString, add attribute filter helper (#5765)
- Increase metric name maximum length from 63 to 255 characters (#5697)
Exporter
- Prometheus exporter: remove non-ucum units from conversion (#5719)
- Prometheus exporter: add units to metric names in TYPE and HELP comments (#5718)
SDK Extensions
- Add support for file based configuration to incubator (#5687, #5751, #5758, #5757, #5755, #5763, #5766, #5773, #5771, #5779)
- Autoconfigure ConfigProperties#getMap filters entries with blank values instead of throwing (#5784)
Semantic conventions
- DEPRECATION:
io.opentelemetry:opentelemetry-semconv
is deprecated for removal. Please useio.opentelemetry.semconv:opentelemetry-semconv:1.21.0-alpha
instead, which is published from open-telemetry/semantic-conventions-java. The new repository is published in lockstep with open-telemetry/semantic-conventions. (#5786)
Project Tooling
- Update Gradle Wrapper from 8.2.1 to 8.3 (#5728)
- Remove dependabot and
update-gradle-wrapper
task in favor of renovate (#5746)
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@breedx-splk
@brunobat
@dashpole
@dependabot
@Emily-Jiang
@erenming
@jack-berg
@jkwatson
@jsuereth
@mateuszrzeszutek
@tigrannajaryan
@trask
@tylerbenson
Version 1.29.0
API
- Update Span javadoc to allow null/empty attr values (#5616)
SDK
- Add Sdk{Signal}ProviderBuilder#addResource(Resource) method to merge Resource with current (#5619)
Metrics
- Add LongHistogramAdviceConfigurer to improve api surface types (#5689)
- Instruments with names which are case-insensitive equal contribute to same metric, advice is not part of instrument identity. (#5701)
Exporter
- Add OtlpHttp{Signal}Exporter#toBuilder() methods (#5652)
- Add OtlpGrpc{Signal}Exporter#toBuilder() methods (#5680)
- Add #toString to OTLP exporters (#5686)
- Break out GrpcSender, GrpcSenderProvider (#5617)
SDK Extensions
- BREAKING: Delete zpages (#5611)
- Initialize file configuration with generated model classes and parse method (#5399)
- Refactor SpiUtil to improve mocking (#5679)
- Switch from snakeyaml to snakeyaml engine (#5691)
- Add experimental autoconfigure support for customizing cardinality limit (#5659)
- Reorganize autoconfigure docs by signal (#5665)
Testing
- Add hasResourceSatisfying to LogRecordDataAssert (#5690)
OpenCensus Shim
- Change OpenCensus shim default sampling to defer to OpenTelemetry (#5604)
Project Tooling
- Update Gradle Wrapper from 8.2 to 8.2.1 (#5618)
- Fix gradle java version requirement warning (#5624)
- Refer to Adoptium/Temurin instead of AdoptOpenJDK (#5636)
- Use OtelVersionClassPlugin instead of reading version from resource (#5622)
- Enforce build-graal success in required status check (#5696)
🙇 Thank you
This release was possible thanks to the following contributors who shared their brilliant ideas and awesome pull requests:
@aabmass
@akats7
@breedx-splk
@cartermp
@chalin
@jack-berg
@jkwatson
@jsuereth
@keithc-ca
@mateuszrzeszutek
@parth1601
@svrnm
@trask
@tylerbenson
@zeitlinger