1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
//go:build go1.18
// +build go1.18
package main
import (
"context"
"log"
"os"
"os/signal"
"time"
"go.opentelemetry.io/contrib/instrumentation/host"
"go.opentelemetry.io/otel/exporters/stdout/stdoutmetric"
"go.opentelemetry.io/otel/sdk/metric"
"go.opentelemetry.io/otel/sdk/resource"
semconv "go.opentelemetry.io/otel/semconv/v1.17.0"
)
var res = resource.NewWithAttributes(
semconv.SchemaURL,
semconv.ServiceName("host-instrumentation-example"),
)
func main() {
exp, err := stdoutmetric.New()
if err != nil {
log.Fatal(err)
}
// Register the exporter with an SDK via a periodic reader.
read := metric.NewPeriodicReader(exp, metric.WithInterval(1*time.Second))
provider := metric.NewMeterProvider(metric.WithResource(res), metric.WithReader(read))
defer func() {
err := provider.Shutdown(context.Background())
if err != nil {
log.Fatal(err)
}
}()
ctx, cancel := signal.NotifyContext(context.Background(), os.Interrupt)
defer cancel()
log.Print("Starting host instrumentation:")
err = host.Start(host.WithMeterProvider(provider))
if err != nil {
log.Fatal(err)
}
<-ctx.Done()
}
|