Skip to content

Commit

Permalink
Clone the diff in GRPC streaming to prevent panics (grafana#3961)
Browse files Browse the repository at this point in the history
* clone diff

Signed-off-by: Joe Elliott <number101010@gmail.com>

* changelog

Signed-off-by: Joe Elliott <number101010@gmail.com>

* add similar logic to final

Signed-off-by: Joe Elliott <number101010@gmail.com>

---------

Signed-off-by: Joe Elliott <number101010@gmail.com>
  • Loading branch information
joe-elliott authored Aug 14, 2024
1 parent e33d407 commit 89b8d7d
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 2 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@
* [BUGFIX] **BREAKING CHANGE** Remove unused properties from the WAL configuration [#3911](https://github.com/grafana/tempo/pull/3911) (@javiermolinar)
* [BUGFIX] Bring back OTEL receiver metrics [#3917](https://github.com/grafana/tempo/pull/3917) (@javiermolinar)
* [BUGFIX] Correct block end time when the ingested traces are outside the ingestion slack [#3954](https://github.com/grafana/tempo/pull/3954) (@javiermolinar)
* [BUGFIX] Fix race condition where a streaming response could be marshalled while being modified in the combiner resulting in a panic. [#3961](https://github.com/grafana/tempo/pull/3961) (@joe-elliott)

## v2.5.0

Expand Down
8 changes: 6 additions & 2 deletions modules/frontend/combiner/common.go
Original file line number Diff line number Diff line change
Expand Up @@ -176,7 +176,9 @@ func (c *genericCombiner[T]) GRPCFinal() (T, error) {
return empty, err
}

return final, nil
// clone the final response to prevent race conditions with marshalling this data
finalClone := proto.Clone(final).(T)
return finalClone, nil
}

func (c *genericCombiner[T]) GRPCDiff() (T, error) {
Expand All @@ -194,7 +196,9 @@ func (c *genericCombiner[T]) GRPCDiff() (T, error) {
return empty, err
}

return diff, nil
// clone the diff to prevent race conditions with marshalling this data
diffClone := proto.Clone(diff)
return diffClone.(T), nil
}

func (c *genericCombiner[T]) erroredResponse() (*http.Response, error) {
Expand Down

0 comments on commit 89b8d7d

Please sign in to comment.