add tracing

This commit is contained in:
2025-11-24 11:37:32 +03:00
parent a8d762668b
commit a0f112506f
7 changed files with 190 additions and 4 deletions

View File

@@ -9,6 +9,7 @@ import (
"github.com/go-chi/chi/middleware"
"github.com/go-chi/chi/v5"
"github.com/juju/zaputil/zapctx"
"go.opentelemetry.io/otel"
"go.uber.org/zap"
"moul.io/chizap"
@@ -17,17 +18,38 @@ import (
"github.com/prometheus/client_golang/prometheus/promhttp"
)
const (
TRACER_NAME = "go_test"
)
var tracer = otel.Tracer(TRACER_NAME)
func someFunc(ctx context.Context) {
_, span := tracer.Start(ctx, "someFunc")
defer span.End()
logger := zapctx.Logger(ctx)
time.Sleep(1 * time.Second)
logger.Info("Hi from SomeFunc")
}
func main() {
ctx := context.Background()
logger, err := logger.GetLogger(false)
if err != nil {
panic(err)
}
shutdown, err := InstallExportPipeline()
if err != nil {
logger.Fatal(err.Error())
}
defer func() {
if err := shutdown(ctx); err != nil {
logger.Fatal(err.Error())
}
}()
r := chi.NewRouter()
logger = logger.With(zap.Any("someKey", "someValue"))
@@ -43,8 +65,10 @@ func main() {
})
r.Get("/", func(w http.ResponseWriter, r *http.Request) {
ctxLocal, span := tracer.Start(r.Context(), "main")
defer span.End()
counter.Inc()
ctx := zapctx.WithLogger(r.Context(), logger)
ctx := zapctx.WithLogger(ctxLocal, logger)
someFunc(ctx)
_, err := w.Write([]byte("welcome"))
if err != nil {