Go
You can setup tracing for your Go application. Check sample configuration on how to setup traces.
Clone
git clone https://github.com/openobserve/sample-tracing-golang
If you don't have Go installed, please install it and then follow below steps.
Open pkg/tel/otel_helper_http.go
file from that repository. and make changes to the highlighted lines below
| package tel
import (
"context"
"fmt"
"os"
"go.opentelemetry.io/otel"
"go.opentelemetry.io/otel/attribute"
"go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp"
"go.opentelemetry.io/otel/propagation"
"go.opentelemetry.io/otel/sdk/resource"
sdktrace "go.opentelemetry.io/otel/sdk/trace"
semconv "go.opentelemetry.io/otel/semconv/v1.4.0"
)
func InitTracerHTTP() *sdktrace.TracerProvider {
otel.SetTextMapPropagator(propagation.NewCompositeTextMapPropagator(
propagation.TraceContext{},
propagation.Baggage{},
))
OTEL_OTLP_HTTP_ENDPOINT := os.Getenv("OTEL_OTLP_HTTP_ENDPOINT")
if OTEL_OTLP_HTTP_ENDPOINT == "" {
OTEL_OTLP_HTTP_ENDPOINT = "<host>:<port>" //without trailing slash
}
OTEL_OTLP_HTTP_ENDPOINT = "api.openobserve.ai"
otlptracehttp.NewClient()
otlpHTTPExporter, err := otlptracehttp.New(context.TODO(),
// otlptracehttp.WithInsecure(), // use http & not https
otlptracehttp.WithEndpoint(OTEL_OTLP_HTTP_ENDPOINT),
otlptracehttp.WithURLPath("/api/default/v1/traces"),
otlptracehttp.WithHeaders(map[string]string{
"Authorization": "Authorization",
}),
)
if err != nil {
fmt.Println("Error creating HTTP OTLP exporter: ", err)
}
res := resource.NewWithAttributes(
semconv.SchemaURL,
// the service name used to display traces in backends
semconv.ServiceNameKey.String("otel1-gin-gonic"),
semconv.ServiceVersionKey.String("0.0.1"),
attribute.String("environment", "test"),
)
tp := sdktrace.NewTracerProvider(
sdktrace.WithSampler(sdktrace.AlwaysSample()),
sdktrace.WithResource(res),
sdktrace.WithBatcher(otlpHTTPExporter),
// sdktrace.WithBatcher(stdExporter),
)
otel.SetTracerProvider(tp)
return tp
}
|
Setup up credentials
You will get url
and Authorization
key here http://cloud.openobserve.ai/ingestion/traces/
Replace the url
and Authorization
key in the pkg/tel/otel_helper_http.go
file
Setup Service/Application
Follow the steps given in the sample-tracing-golang readme and then start server
The server is now running, navigate to http://localhost:8080/
Refresh page couple of times to get more traces exported.
data:image/s3,"s3://crabby-images/1726f/1726f533f2d4ca40fc2197e2f1cecd7eff4467b5" alt="Traces Sample Configration"
Traces are captured, you can check these captured traces here https://cloud.openobserve.ai/traces
data:image/s3,"s3://crabby-images/1831e/1831e9115504d0b9e412d84f69c894847e25e7a0" alt="Traces Page"
Filter traces with your service name otel1-gin-gonic
data:image/s3,"s3://crabby-images/6fa98/6fa98da0f3510835f5c7e95c0edeed3eb04361a7" alt="Filter traces with service name"
Click on any trace to check trace data
data:image/s3,"s3://crabby-images/bcf9e/bcf9e0597fb7f2d87faf0498c676e1225417d232" alt="Trace details"
Trace can have multiple spans, each span represents single operation or task within that trace. Click on any span to check span details.
data:image/s3,"s3://crabby-images/4786e/4786e1fade4d52a6512f62965afbdef40e5c95ea" alt="Trace details"