From 0dc3b87f1782c3098bb87a0ec4062765c35bbac2 Mon Sep 17 00:00:00 2001 From: rosstimothy <39066650+rosstimothy@users.noreply.github.com> Date: Fri, 26 Jul 2024 10:56:25 -0400 Subject: [PATCH] Reduce log spam in transport service (#44686) The grpc status conversion handled by trace does not map a canceled status to context.Canceled which leads to additional log spam that confuses users. --- lib/srv/transport/transportv1/transport.go | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lib/srv/transport/transportv1/transport.go b/lib/srv/transport/transportv1/transport.go index 756083eab30f0..f019875186af7 100644 --- a/lib/srv/transport/transportv1/transport.go +++ b/lib/srv/transport/transportv1/transport.go @@ -29,8 +29,10 @@ import ( "github.com/gravitational/trace" "github.com/sirupsen/logrus" "golang.org/x/crypto/ssh/agent" + "google.golang.org/grpc/codes" "google.golang.org/grpc/credentials" "google.golang.org/grpc/peer" + "google.golang.org/grpc/status" "github.com/gravitational/teleport" transportv1pb "github.com/gravitational/teleport/api/gen/proto/go/teleport/transport/v1" @@ -244,7 +246,7 @@ func (s *Service) ProxySSH(stream transportv1pb.TransportService_ProxySSHServer) for { req, err := stream.Recv() if err != nil { - if !utils.IsOKNetworkError(err) && !errors.Is(err, context.Canceled) { + if !utils.IsOKNetworkError(err) && !errors.Is(err, context.Canceled) && status.Code(err) != codes.Canceled { s.cfg.Logger.Errorf("ssh stream terminated unexpectedly: %v", err) }