mirror of
https://github.com/minio/minio.git
synced 2025-01-13 07:53:21 -05:00
Add extra protection for grid reconnects (#18840)
Race checks would occasionally show race on handleMsgWg WaitGroup by debug messages (used in test only). Use the `connMu` mutex to protect this against concurrent Wait/Add. Fixes #18827
This commit is contained in:
parent
65c4d550cb
commit
feeeef71f1
@ -831,7 +831,9 @@ func (c *Connection) reconnected() {
|
|||||||
c.outgoing.Clear()
|
c.outgoing.Clear()
|
||||||
|
|
||||||
// Wait for existing to exit
|
// Wait for existing to exit
|
||||||
|
c.connMu.Lock()
|
||||||
c.handleMsgWg.Wait()
|
c.handleMsgWg.Wait()
|
||||||
|
c.connMu.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Connection) updateState(s State) {
|
func (c *Connection) updateState(s State) {
|
||||||
@ -855,7 +857,9 @@ func (c *Connection) updateState(s State) {
|
|||||||
|
|
||||||
func (c *Connection) handleMessages(ctx context.Context, conn net.Conn) {
|
func (c *Connection) handleMessages(ctx context.Context, conn net.Conn) {
|
||||||
// Read goroutine
|
// Read goroutine
|
||||||
|
c.connMu.Lock()
|
||||||
c.handleMsgWg.Add(2)
|
c.handleMsgWg.Add(2)
|
||||||
|
c.connMu.Unlock()
|
||||||
ctx, cancel := context.WithCancelCause(ctx)
|
ctx, cancel := context.WithCancelCause(ctx)
|
||||||
go func() {
|
go func() {
|
||||||
defer func() {
|
defer func() {
|
||||||
@ -1534,7 +1538,9 @@ func (c *Connection) debugMsg(d debugMsg, args ...any) {
|
|||||||
c.debugInConn.Close()
|
c.debugInConn.Close()
|
||||||
}
|
}
|
||||||
case debugWaitForExit:
|
case debugWaitForExit:
|
||||||
|
c.connMu.Lock()
|
||||||
c.handleMsgWg.Wait()
|
c.handleMsgWg.Wait()
|
||||||
|
c.connMu.Unlock()
|
||||||
case debugSetConnPingDuration:
|
case debugSetConnPingDuration:
|
||||||
c.connMu.Lock()
|
c.connMu.Lock()
|
||||||
defer c.connMu.Unlock()
|
defer c.connMu.Unlock()
|
||||||
|
Loading…
Reference in New Issue
Block a user