From 1355d7e9f850995834cdee93bc759ae58ff7aa3d Mon Sep 17 00:00:00 2001 From: Laura Brehm Date: Fri, 20 Sep 2024 01:29:19 +0100 Subject: [PATCH] telemetry: fix early meterprovider shutdown In 4b5a196fee11e82e15d2c2c36ba2883e5717fde3, we changed the CLI global meter provider shutdown in order to handle any error returned by the metric export. Unfortunately, we dropped a `defer` during the fix, which causes the meter provider to be immediately shutdown after being created and metrics to not be collected/exporter. Signed-off-by: Laura Brehm --- cmd/docker/docker.go | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/cmd/docker/docker.go b/cmd/docker/docker.go index ee83bd76d69f..8b15b76f8ec7 100644 --- a/cmd/docker/docker.go +++ b/cmd/docker/docker.go @@ -358,9 +358,11 @@ func runDocker(ctx context.Context, dockerCli *command.DockerCli) error { mp := dockerCli.MeterProvider() if mp, ok := mp.(command.MeterProvider); ok { - if err := mp.Shutdown(ctx); err != nil { - otel.Handle(err) - } + defer func() { + if err := mp.Shutdown(ctx); err != nil { + otel.Handle(err) + } + }() } else { fmt.Fprint(dockerCli.Err(), "Warning: Unexpected OTEL error, metrics may not be flushed") }