From b1e5ebc9c607d063bea959c3bfd229915359988b Mon Sep 17 00:00:00 2001 From: Benjamin Wang Date: Fri, 17 Jan 2025 19:16:47 +0000 Subject: [PATCH] Ensure all goroutines created by StartEtcd to complete before closing the errc Signed-off-by: Benjamin Wang --- server/embed/etcd.go | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/server/embed/etcd.go b/server/embed/etcd.go index f5fa2c2c692..fe2450401de 100644 --- a/server/embed/etcd.go +++ b/server/embed/etcd.go @@ -607,7 +607,9 @@ func (e *Etcd) servePeers() { // start peer servers in a goroutine for _, pl := range e.Peers { + e.wg.Add(1) go func(l *peerListener) { + defer e.wg.Done() u := l.Addr().String() e.cfg.logger.Info( "serving peer traffic", @@ -774,7 +776,9 @@ func (e *Etcd) serveClients() { // start client servers in each goroutine for _, sctx := range e.sctxs { + e.wg.Add(1) go func(s *serveCtx) { + defer e.wg.Done() e.errHandler(s.serve(e.Server, &e.cfg.ClientTLSInfo, mux, e.errHandler, e.grpcGatewayDial(splitHTTP), splitHTTP, gopts...)) }(sctx) } @@ -859,7 +863,9 @@ func (e *Etcd) serveMetrics() (err error) { return err } e.metricsListeners = append(e.metricsListeners, ml) + e.wg.Add(1) go func(u url.URL, ln net.Listener) { + defer e.wg.Done() e.cfg.logger.Info( "serving metrics", zap.String("address", u.String()), @@ -872,9 +878,6 @@ func (e *Etcd) serveMetrics() (err error) { } func (e *Etcd) errHandler(err error) { - e.wg.Add(1) - defer e.wg.Done() - if err != nil { e.GetLogger().Error("setting up serving from embedded etcd failed.", zap.Error(err)) }