diff --git a/cli-plugins/plugin/plugin.go b/cli-plugins/plugin/plugin.go index d4f38d74cdca..8cce73d9acda 100644 --- a/cli-plugins/plugin/plugin.go +++ b/cli-plugins/plugin/plugin.go @@ -45,6 +45,7 @@ func RunPlugin(dockerCli *command.DockerCli, plugin *cobra.Command, meta manager if os.Getenv("DOCKER_CLI_PLUGIN_USE_DIAL_STDIO") != "" { opts = append(opts, withPluginClientConn(plugin.Name())) } + opts = append(opts, command.WithEnableGlobalMeterProvider(), command.WithEnableGlobalTracerProvider()) err = tcmd.Initialize(opts...) ogRunE := cmd.RunE if ogRunE == nil { diff --git a/cli/cobra.go b/cli/cobra.go index f6a69ae0701d..1016fa4e5e14 100644 --- a/cli/cobra.go +++ b/cli/cobra.go @@ -166,6 +166,7 @@ func (tcmd *TopLevelCommand) HandleGlobalFlags() (*cobra.Command, []string, erro // arguments are in `flags.Args()`. if err := flags.Parse(tcmd.args); err != nil { // Our FlagErrorFunc uses the cli, make sure it is initialized + // TODO(thaJeztah): does this need OTEL global tracer and meter to be configured? if err := tcmd.Initialize(); err != nil { return nil, nil, err } diff --git a/cli/command/cli.go b/cli/command/cli.go index d8c3460efa3c..06478c9c776e 100644 --- a/cli/command/cli.go +++ b/cli/command/cli.go @@ -92,6 +92,8 @@ type DockerCli struct { // this may be replaced by explicitly passing a context to functions that // need it. baseCtx context.Context + + enableGlobalMeter, enableGlobalTracer bool } // DefaultVersion returns api.defaultVersion. @@ -284,8 +286,12 @@ func (cli *DockerCli) Initialize(opts *cliflags.ClientOptions, ops ...CLIOption) } // TODO(krissetto): pass ctx to the funcs instead of using this - cli.createGlobalMeterProvider(cli.baseCtx) - cli.createGlobalTracerProvider(cli.baseCtx) + if cli.enableGlobalMeter { + cli.createGlobalMeterProvider(cli.baseCtx) + } + if cli.enableGlobalTracer { + cli.createGlobalTracerProvider(cli.baseCtx) + } return nil } diff --git a/cli/command/telemetry_options.go b/cli/command/telemetry_options.go new file mode 100644 index 000000000000..0a6590b53be0 --- /dev/null +++ b/cli/command/telemetry_options.go @@ -0,0 +1,21 @@ +package command + +// WithEnableGlobalMeterProvider configures the DockerCli to create a new +// MeterProvider from the initialized DockerCli struct, and set it as +// the global meter provider. +func WithEnableGlobalMeterProvider() CLIOption { + return func(cli *DockerCli) error { + cli.enableGlobalMeter = true + return nil + } +} + +// WithEnableGlobalTracerProvider configures the DockerCli to create a new +// TracerProvider from the initialized DockerCli struct, and set it as +// the global tracer provider. +func WithEnableGlobalTracerProvider() CLIOption { + return func(cli *DockerCli) error { + cli.enableGlobalTracer = true + return nil + } +} diff --git a/cmd/docker/docker.go b/cmd/docker/docker.go index 6b8f4ab58965..7825c7d35455 100644 --- a/cmd/docker/docker.go +++ b/cmd/docker/docker.go @@ -354,7 +354,7 @@ func runDocker(ctx context.Context, dockerCli *command.DockerCli) error { return err } - if err := tcmd.Initialize(); err != nil { + if err := tcmd.Initialize(command.WithEnableGlobalMeterProvider(), command.WithEnableGlobalTracerProvider()); err != nil { return err }