From 691adf365a04938f3a5a75fa5345173a6a974a9f Mon Sep 17 00:00:00 2001 From: Tom Manville Date: Thu, 10 Oct 2024 11:33:03 -0700 Subject: [PATCH] [minor] Prefer signal.NotifyContext to signal.Notify in kanx (#3180) --- pkg/kanx/server.go | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/pkg/kanx/server.go b/pkg/kanx/server.go index a708557157..208c5115cb 100644 --- a/pkg/kanx/server.go +++ b/pkg/kanx/server.go @@ -199,14 +199,14 @@ func NewServer() *Server { } func (s *Server) Serve(ctx context.Context, addr string) error { - stopChan := make(chan os.Signal, 1) - signal.Notify(stopChan, syscall.SIGTERM, syscall.SIGINT) + ctx, can := signal.NotifyContext(ctx, syscall.SIGTERM, syscall.SIGINT) + defer can() go func() { - select { - case sig := <-stopChan: - log.Info().Print("Gracefully stopping. Received Signal", field.M{"signal": sig}) - case <-ctx.Done(): - log.Info().Print("Gracefully stopping. Context canceled") + <-ctx.Done() + if err := ctx.Err(); err == context.Canceled { + log.Info().Print("Gracefully stopping. Parent context canceled") + } else { + log.Info().WithError(err).Print("Gracefully stopping.") } s.grpcs.GracefulStop() }()