package main import ( "context" "log" "os" "os/signal" "syscall" "go.uber.org/zap" grpcquerynode "github.com/zilliztech/milvus-distributed/internal/distributed/querynode" ) func main() { // Creates server. ctx, cancel := context.WithCancel(context.Background()) svr := grpcquerynode.NewServer(ctx) if err := svr.Init(); err != nil { panic(err) } sc := make(chan os.Signal, 1) signal.Notify(sc, syscall.SIGHUP, syscall.SIGINT, syscall.SIGTERM, syscall.SIGQUIT) var sig os.Signal go func() { sig = <-sc cancel() }() if err := svr.Start(); err != nil { panic(err) } <-ctx.Done() log.Print("Got signal to exit", zap.String("signal", sig.String())) if err := svr.Stop(); err != nil { panic(err) } switch sig { case syscall.SIGTERM: exit(0) default: exit(1) } } func exit(code int) { os.Exit(code) }