bugfix:typha:avoid concurrent map iteration and map write #7743
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
We discovered a panic in typha (v3.21.4) due to concurrent iteration and writing on the map.
the method connection sendMsg as the following
The reason why typha panic is h.logCxt.Data is not thread safe see the issue sirupsen/logrus#1046 and sirupsen/logrus#1272. We cannot change the Data in different goroutine (log hooks).
Here is the reproduced code: try with
go run -race *.go
This PR is a quick fix that avoids typha panic by not using h.logCxt in sendMsg (sendMsg callers already print the logs when its' error).
The optimal approach would be to refactor the logutils in order to obtain the FILENAME and LINE NUMBER, as suggested in sirupsen/logrus#63.
Related issues/PRs
Todos
Release Note
Reminder for the reviewer
Make sure that this PR has the correct labels and milestone set.
Every PR needs one
docs-*
label.docs-pr-required
: This change requires a change to the documentation that has not been completed yet.docs-completed
: This change has all necessary documentation completed.docs-not-required
: This change has no user-facing impact and requires no docs.Every PR needs one
release-note-*
label.release-note-required
: This PR has user-facing changes. Most PRs should have this label.release-note-not-required
: This PR has no user-facing changes.Other optional labels:
cherry-pick-candidate
: This PR should be cherry-picked to an earlier release. For bug fixes only.needs-operator-pr
: This PR is related to install and requires a corresponding change to the operator.