From cea79796801217ae8f22c0c54abcdb64c072e396 Mon Sep 17 00:00:00 2001 From: bb7133 Date: Tue, 15 Mar 2022 15:15:52 +0800 Subject: [PATCH] cherry pick #32809 to release-5.2 Signed-off-by: ti-srebot --- server/conn.go | 16 ++++++++++------ server/server.go | 5 +++++ 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/server/conn.go b/server/conn.go index 561dae86c7b80..174cdcd0f6245 100644 --- a/server/conn.go +++ b/server/conn.go @@ -964,12 +964,16 @@ func (cc *clientConn) Run(ctx context.Context) { if err != nil { if terror.ErrorNotEqual(err, io.EOF) { if netErr, isNetErr := errors.Cause(err).(net.Error); isNetErr && netErr.Timeout() { - idleTime := time.Since(start) - logutil.Logger(ctx).Info("read packet timeout, close this connection", - zap.Duration("idle", idleTime), - zap.Uint64("waitTimeout", waitTimeout), - zap.Error(err), - ) + if atomic.LoadInt32(&cc.status) == connStatusWaitShutdown { + logutil.Logger(ctx).Info("read packet timeout because of killed connection") + } else { + idleTime := time.Since(start) + logutil.Logger(ctx).Info("read packet timeout, close this connection", + zap.Duration("idle", idleTime), + zap.Uint64("waitTimeout", waitTimeout), + zap.Error(err), + ) + } } else { errStack := errors.ErrorStack(err) if !strings.Contains(errStack, "use of closed network connection") { diff --git a/server/server.go b/server/server.go index d4e3ced2f5b95..ba05c2a1731e4 100644 --- a/server/server.go +++ b/server/server.go @@ -642,6 +642,11 @@ func killConn(conn *clientConn) { if cancelFunc != nil { cancelFunc() } + if conn.bufReadConn != nil { + if err := conn.bufReadConn.SetReadDeadline(time.Now()); err != nil { + logutil.BgLogger().Warn("error setting read deadline for kill.", zap.Error(err)) + } + } } // KillAllConnections kills all connections when server is not gracefully shutdown.