Releases: thanos-io/thanos
v0.41.0
This is a good one, among several bug fixes, we have batched Series and Query RPCs now - this should lead to drastic improvements in network bandwidth and decent improvements in CPU/Memory usage of Querier and all its endpoints.
Changes
Fixed
- #8378: Store: fix the reuse of dirty posting slices
- #8558: Query-Frontend: Fix not logging requests when external-prefix is set in query
- #8254 Receive: Endless loop of retried replication with capnproto and distributors
- #8618: Query-Frontend: ensure slow query and stats logging on request failures
- #8480: Store: fix(readerpool): avoid inserting nil LazyBinaryReader on error to avoid panic
Added
- #8623: Query: Enable batching of Series per SeriesResponse.
- #8582: Sidecar: support --storage.tsdb.delay-compact-file.path Prometheus flag.
- #8595: *: add --shipper.upload-compacted flag for controlling upload concurrency in components that use shippper
Changed
- #8630: Receive: breaking
⚠️ shuffle sharding now uses consistent hashing for stability on scale. Existing tenant-to-node assignments will change on upgrade. - #8555: Promu: re-add Darwin and FreeBSD as release platforms
- #8661: Upgrade Prometheus to v3.8.0.
tsdb.enable-native-histogramsflag in Receiver and Ruler becomes a no-op and deprecated. Now native histogram ingestion is always enabled.
New Contributors
- @hek2mgl made their first contribution in #8425
- @jrisebor made their first contribution in #8569
- @prymitive made their first contribution in #8582
- @abhiweye made their first contribution in #8592
- @TessaIO made their first contribution in #8556
- @dethi made their first contribution in #8622
- @adezxc made their first contribution in #8623
- @erlan-z made their first contribution in #8480
- @dowgird made their first contribution in #8595
- @pvlltvk made their first contribution in #8618
v0.41.0-rc.1
Like v0.41.0-rc.0 but with additional cherry-pick of:
downgrade grpc-go to fix memory leak: #8671
v0.41.0-rc.0
This is a good one, among several bug fixes, we have batched Series and Query RPCs now - this should lead to drastic improvements in network bandwidth and decent improvements in CPU/Memory usage of Querier and all its endpoints.
Changes
Fixed
- #8378: Store: fix the reuse of dirty posting slices
- #8558: Query-Frontend: Fix not logging requests when external-prefix is set in query
- #8254 Receive: Endless loop of retried replication with capnproto and distributors
- #8618: Query-Frontend: ensure slow query and stats logging on request failures
- #8480: Store: fix(readerpool): avoid inserting nil LazyBinaryReader on error to avoid panic
Added
- #8623: Query: Enable batching of Series per SeriesResponse.
- #8582: Sidecar: support --storage.tsdb.delay-compact-file.path Prometheus flag.
- #8595: *: add --shipper.upload-compacted flag for controlling upload concurrency in components that use shippper
Changed
- #8630: Receive: breaking
⚠️ shuffle sharding now uses consistent hashing for stability on scale. Existing tenant-to-node assignments will change on upgrade. - #8555: Promu: re-add Darwin and FreeBSD as release platforms
- #8661: Upgrade Prometheus to v3.8.0.
tsdb.enable-native-histogramsflag in Receiver and Ruler becomes a no-op and deprecated. Now native histogram ingestion is always enabled.
New Contributors
- @hek2mgl made their first contribution in #8425
- @jrisebor made their first contribution in #8569
- @prymitive made their first contribution in #8582
- @abhiweye made their first contribution in #8592
- @TessaIO made their first contribution in #8556
- @dethi made their first contribution in #8622
- @adezxc made their first contribution in #8623
- @erlan-z made their first contribution in #8480
- @dowgird made their first contribution in #8595
- @pvlltvk made their first contribution in #8618
v0.40.1
-- There is still a performance regression in this release #8549 that we are working on fixing --
This fix fixes a performance regression in the gRPC layer.
What's Changed
- Pull extgrpc fix and release 0.40.1 by @GiedriusS in #8547
Full Changelog: v0.40.0...v0.40.1
v0.40.0
v0.40.0 - 2025 10 27
Fixed
- #8334 Query: wait for initial endpoint discovery before becoming ready
- #8486 Receive: fix exemplar label corruption from Cap'n Proto memory references
- #8499 Query: support UTF-8 label names for the
/api/v1/label/:name/valuesAPI. - #8336 store: fix race between lazy index header creation
Added
- #8366 Store: optionally ignore Parquet migrated blocks
- #8359 Tools: add
--shipper.upload-compactedflag for uploading compacted blocks to bucket upload-blocks - #8484 Query: add
/api/v1/status/tsdbAPI endpoint. - #8454 Compact: ensure we don't mark blocks for deletion again after just deleting them
- #8410 Compact: ignore blocks with deletion mark in partial deletes
Changed
- #8370 Query: announced labelset now reflects relabel-config
- #8464 Query: assume that we do not unmark a block for deletion. This solves a race between Thanos Store and Compactor.
- #8402 Query/Receive: trim labelsets in String()
- #8334 Query: wait for initial endpoint discovery before becoming ready
- #8401 block/compact: rework consistency check, make writers only write
- #8389 block: bust cache if modified timestamp differs
New Contributors
- @paul-hsieh made their first contribution in #8321
- @jdgeisler made their first contribution in #8359
- @NickGoog made their first contribution in #8400
- @erikgb made their first contribution in #8427
- @parthivrmenon made their first contribution in #8456
- @dbuchanaRH made their first contribution in #8486
Full Changelog: v0.39.2...v0.40.0
v0.40.0-rc.0
v0.40.0-rc.0 - 2025 10 20
Fixed
- #8334 Query: wait for initial endpoint discovery before becoming ready
- #8486 Receive: fix exemplar label corruption from Cap'n Proto memory references
- #8499 Query: support UTF-8 label names for the
/api/v1/label/:name/valuesAPI. - #8336 store: fix race between lazy index header creation
Added
- #8366 Store: optionally ignore Parquet migrated blocks
- #8359 Tools: add
--shipper.upload-compactedflag for uploading compacted blocks to bucket upload-blocks - #8484 Query: add
/api/v1/status/tsdbAPI endpoint. - #8454 Compact: ensure we don't mark blocks for deletion again after just deleting them
- #8410 Compact: ignore blocks with deletion mark in partial deletes
Changed
- #8370 Query: announced labelset now reflects relabel-config
- #8464 Query: assume that we do not unmark a block for deletion. This solves a race between Thanos Store and Compactor.
- #8402 Query/Receive: trim labelsets in String()
- #8334 Query: wait for initial endpoint discovery before becoming ready
- #8401 block/compact: rework consistency check, make writers only write
- #8389 block: bust cache if modified timestamp differs
New Contributors
- @paul-hsieh made their first contribution in #8321
- @jdgeisler made their first contribution in #8359
- @NickGoog made their first contribution in #8400
- @erikgb made their first contribution in #8427
- @parthivrmenon made their first contribution in #8456
- @dbuchanaRH made their first contribution in #8486
Full Changelog: v0.39.2...v0.40.0-rc.0
v0.39.2
Fixes two issues with the distributed query engine.
Fixed
- #8374 Query: fix panic when concurrently accessing annotations map
- #8375 Query: fix native histogram buckets in distributed queries
Full Changelog: v0.39.1...v0.39.2
v0.39.1
v0.39.0
In short: there are a bunch of fixes and small improvements. The shining items in this release are memory usage improvements in Thanos Query and shuffle sharding support in Thanos Receiver. Information about shuffle sharding support is available in the documentation. Thank you to all contributors!
Added
- #8308 Receive: Prometheus counters for pending write requests and series requests
- #8225 tools: Extend bucket ls options.
- #8238 Receive: add shuffle sharding support
- #8284 Store: Add
--disable-admin-operationsFlag to Store Gateway - #8245 Querier/Query-Frontend/Ruler: Add
--enable-feature=promql-experimental-functionsflag option to enable using promQL experimental functions in respective Thanos components - #8259 Shipper: Add
--shipper.skip-corrupted-blocksflag to allowSync()to continue upload when finding a corrupted block
Changed
- #8282 Force sync writes to meta.json in case of host crash
- #8192 Sidecar: fix default get config timeout
- #8202 Receive: Unhide
--tsdb.enable-native-histogramsflag - #8315 Query-Frontend: only ready if downstream is ready
Removed
- #8289 Receive: breaking
⚠️ Removed migration of legacy-TSDB to multi-TSDB. Ensure you are running version >0.13
Fixed
- #8199 Query: handle panics or nil pointer dereference in querier gracefully when query analyze returns nil
- #8211 Query: fix panic on nested partial response in distributed instant query
- #8216 Query/Receive: fix iter race between
next()andstop()introduced in #7821. - #8212 Receive: Ensure forward/replication metrics are incremented in err cases
- #8296 Query: limit LazyRetrieval memory buffer size
New Contributors
- @naohiroo made their first contribution in #8190
- @vCra made their first contribution in #8202
- @yuchen-db made their first contribution in #8216
- @adrmaas made their first contribution in #8210
- @machine424 made their first contribution in #8014
- @dronenb made their first contribution in #8263
- @siavashs made their first contribution in #8268
- @anna-tran made their first contribution in #8282
- @Naman-B-Parlecha made their first contribution in #8266
- @gabyfulchic made their first contribution in #8252
- @GregSharpe1 made their first contribution in #8306
- @hczhu made their first contribution in #8296
Full Changelog: v0.38.0...v0.39.0
v0.39.0-rc.0
In short: there are a bunch of fixes and small improvements. The shining items in this release are memory usage improvements in Thanos Query and shuffle sharding support in Thanos Receiver. Information about shuffle sharding support is available in the documentation. Thank you to all contributors!
Added
- #8308 Receive: Prometheus counters for pending write requests and series requests
- #8225 tools: Extend bucket ls options.
- #8238 Receive: add shuffle sharding support
- #8284 Store: Add
--disable-admin-operationsFlag to Store Gateway - #8245 Querier/Query-Frontend/Ruler: Add
--enable-feature=promql-experimental-functionsflag option to enable using promQL experimental functions in respective Thanos components - #8259 Shipper: Add
--shipper.skip-corrupted-blocksflag to allowSync()to continue upload when finding a corrupted block
Changed
- #8282 Force sync writes to meta.json in case of host crash
- #8192 Sidecar: fix default get config timeout
- #8202 Receive: Unhide
--tsdb.enable-native-histogramsflag - #8315 Query-Frontend: only ready if downstream is ready
Removed
- #8289 Receive: breaking
⚠️ Removed migration of legacy-TSDB to multi-TSDB. Ensure you are running version >0.13
Fixed
- #8199 Query: handle panics or nil pointer dereference in querier gracefully when query analyze returns nil
- #8211 Query: fix panic on nested partial response in distributed instant query
- #8216 Query/Receive: fix iter race between
next()andstop()introduced in #7821. - #8212 Receive: Ensure forward/replication metrics are incremented in err cases
- #8296 Query: limit LazyRetrieval memory buffer size
New Contributors
- @naohiroo made their first contribution in #8190
- @vCra made their first contribution in #8202
- @yuchen-db made their first contribution in #8216
- @adrmaas made their first contribution in #8210
- @machine424 made their first contribution in #8014
- @dronenb made their first contribution in #8263
- @siavashs made their first contribution in #8268
- @anna-tran made their first contribution in #8282
- @Naman-B-Parlecha made their first contribution in #8266
- @gabyfulchic made their first contribution in #8252
- @GregSharpe1 made their first contribution in #8306
- @hczhu made their first contribution in #8296
Full Changelog: v0.38.0...v0.39.0-rc.0