mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
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:
parent
01ee49045e
commit
472c2d828c
@ -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)
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user