// Copyright The OpenTelemetry Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package stdoutmetric_test import ( "context" "fmt" "log" "go.opentelemetry.io/otel/attribute" "go.opentelemetry.io/otel/exporters/stdout/stdoutmetric" "go.opentelemetry.io/otel/metric" "go.opentelemetry.io/otel/metric/global" "go.opentelemetry.io/otel/metric/instrument/syncint64" controller "go.opentelemetry.io/otel/sdk/metric/controller/basic" processor "go.opentelemetry.io/otel/sdk/metric/processor/basic" "go.opentelemetry.io/otel/sdk/metric/selector/simple" ) const ( instrumentationName = "github.com/instrumentron" instrumentationVersion = "v0.1.0" ) var ( loopCounter syncint64.Counter paramValue syncint64.Histogram nameKey = attribute.Key("function.name") ) func add(ctx context.Context, x, y int64) int64 { nameKV := nameKey.String("add") loopCounter.Add(ctx, 1, nameKV) paramValue.Record(ctx, x, nameKV) paramValue.Record(ctx, y, nameKV) return x + y } func multiply(ctx context.Context, x, y int64) int64 { nameKV := nameKey.String("multiply") loopCounter.Add(ctx, 1, nameKV) paramValue.Record(ctx, x, nameKV) paramValue.Record(ctx, y, nameKV) return x * y } func InstallExportPipeline(ctx context.Context) (func(context.Context) error, error) { exporter, err := stdoutmetric.New(stdoutmetric.WithPrettyPrint()) if err != nil { return nil, fmt.Errorf("creating stdoutmetric exporter: %w", err) } pusher := controller.New( processor.NewFactory( simple.NewWithInexpensiveDistribution(), exporter, ), controller.WithExporter(exporter), ) if err = pusher.Start(ctx); err != nil { log.Fatalf("starting push controller: %v", err) } global.SetMeterProvider(pusher) meter := global.Meter(instrumentationName, metric.WithInstrumentationVersion(instrumentationVersion)) loopCounter, err = meter.SyncInt64().Counter("function.loops") if err != nil { log.Fatalf("creating instrument: %v", err) } paramValue, err = meter.SyncInt64().Histogram("function.param") if err != nil { log.Fatalf("creating instrument: %v", err) } return pusher.Stop, nil } func Example() { ctx := context.Background() // TODO: Registers a meter Provider globally. shutdown, err := InstallExportPipeline(ctx) if err != nil { log.Fatal(err) } defer func() { if err := shutdown(ctx); err != nil { log.Fatal(err) } }() log.Println("the answer is", add(ctx, multiply(ctx, multiply(ctx, 2, 2), 10), 2)) }