Fix waitgroup add after wait on config reload (#14584)

Fix `panic: "POST /minio/peer/v21/signalservice?signal=2": sync: WaitGroup is reused before previous Wait has returned`

Log entries already on the channel would cause `logEntry` to increment the
 waitgroup when sending messages, after Cancel has been called.

Instead of tracking every single message, just check the send goroutine. Faster 
and safe, since it will not decrement until the channel is closed.

Regression from #14289
This commit is contained in:
Klaus Post 2022-03-19 09:15:45 -07:00 committed by GitHub
parent 01ee49045e
commit 472c2d828c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 5 additions and 7 deletions

View File

@ -128,9 +128,6 @@ func acceptedResponseStatusCode(code int) bool {
} }
func (h *Target) logEntry(entry interface{}) { func (h *Target) logEntry(entry interface{}) {
h.wg.Add(1)
defer h.wg.Done()
logJSON, err := json.Marshal(&entry) logJSON, err := json.Marshal(&entry)
if err != nil { if err != nil {
return return
@ -181,6 +178,8 @@ func (h *Target) startHTTPLogger() {
// Create a routine which sends json logs received // Create a routine which sends json logs received
// from an internal channel. // from an internal channel.
go func() { go func() {
h.wg.Add(1)
defer h.wg.Done()
for entry := range h.logCh { for entry := range h.logCh {
h.logEntry(entry) h.logEntry(entry)
} }

View File

@ -27,7 +27,7 @@ import (
"sync" "sync"
"sync/atomic" "sync/atomic"
sarama "github.com/Shopify/sarama" "github.com/Shopify/sarama"
saramatls "github.com/Shopify/sarama/tools/tls" saramatls "github.com/Shopify/sarama/tools/tls"
"github.com/minio/minio/internal/logger/message/audit" "github.com/minio/minio/internal/logger/message/audit"
@ -62,9 +62,6 @@ func (h *Target) Send(entry interface{}, errKind string) error {
} }
func (h *Target) logEntry(entry interface{}) { func (h *Target) logEntry(entry interface{}) {
h.wg.Add(1)
defer h.wg.Done()
logJSON, err := json.Marshal(&entry) logJSON, err := json.Marshal(&entry)
if err != nil { if err != nil {
return return
@ -90,6 +87,8 @@ func (h *Target) startKakfaLogger() {
// Create a routine which sends json logs received // Create a routine which sends json logs received
// from an internal channel. // from an internal channel.
go func() { go func() {
h.wg.Add(1)
defer h.wg.Done()
for entry := range h.logCh { for entry := range h.logCh {
h.logEntry(entry) h.logEntry(entry)
} }