Skip to content

Commit 6845906

Browse files
takanuva15darccio
andauthored
feat(contrib): Add rs/zerolog ddtracer integration (#4370)
Co-authored-by: Dario Castañé <dario.castane@datadoghq.com>
1 parent dd05598 commit 6845906

File tree

20 files changed

+803
-4
lines changed

20 files changed

+803
-4
lines changed

contrib/rs/zerolog/example_test.go

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
// Unless explicitly stated otherwise all files in this repository are licensed
2+
// under the Apache License Version 2.0.
3+
// This product includes software developed at Datadog (https://www.datadoghq.com/).
4+
// Copyright 2022 Datadog, Inc.
5+
6+
package zerolog_test
7+
8+
import (
9+
"context"
10+
"os"
11+
"time"
12+
13+
"github.com/rs/zerolog"
14+
15+
ddzerolog "github.com/DataDog/dd-trace-go/contrib/rs/zerolog/v2"
16+
17+
"github.com/DataDog/dd-trace-go/v2/ddtrace/tracer"
18+
)
19+
20+
func ExampleHook() {
21+
_ = tracer.Start()
22+
defer tracer.Stop()
23+
// Ensure your tracer is started and stopped
24+
// Setup zerolog, do this once at the beginning of your program
25+
zlog := zerolog.New(os.Stdout).
26+
Hook(&ddzerolog.DDContextLogHook{})
27+
28+
span, sctx := tracer.StartSpanFromContext(context.Background(), "mySpan")
29+
defer span.Finish()
30+
31+
// Pass the current span context to the logger (Time is set for consistency in output here)
32+
cLog := zlog.Info().Ctx(sctx).Time("time", time.Date(2000, 1, 1, 1, 1, 1, 0, time.UTC))
33+
// Log as desired using the context-aware logger
34+
cLog.Msg("Completed some work!")
35+
// You should see:
36+
// {"dd.span_id":0,"dd.trace_id":0,"level":"info","msg":"Completed some work!","time":"2000-01-01T01:01:01Z"}
37+
}

contrib/rs/zerolog/go.mod

Lines changed: 86 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,86 @@
1+
module github.com/DataDog/dd-trace-go/contrib/rs/zerolog/v2
2+
3+
go 1.25.0
4+
5+
require (
6+
github.com/DataDog/dd-trace-go/v2 v2.7.0-dev.1
7+
github.com/rs/zerolog v1.34.0
8+
github.com/stretchr/testify v1.11.1
9+
)
10+
11+
require (
12+
github.com/DataDog/datadog-agent/comp/core/tagger/origindetection v0.75.2 // indirect
13+
github.com/DataDog/datadog-agent/pkg/obfuscate v0.75.2 // indirect
14+
github.com/DataDog/datadog-agent/pkg/opentelemetry-mapping-go/otlp/attributes v0.75.2 // indirect
15+
github.com/DataDog/datadog-agent/pkg/proto v0.75.2 // indirect
16+
github.com/DataDog/datadog-agent/pkg/remoteconfig/state v0.75.2 // indirect
17+
github.com/DataDog/datadog-agent/pkg/template v0.75.2 // indirect
18+
github.com/DataDog/datadog-agent/pkg/trace v0.75.2 // indirect
19+
github.com/DataDog/datadog-agent/pkg/util/log v0.75.2 // indirect
20+
github.com/DataDog/datadog-agent/pkg/util/scrubber v0.75.2 // indirect
21+
github.com/DataDog/datadog-agent/pkg/version v0.75.2 // indirect
22+
github.com/DataDog/datadog-go/v5 v5.8.2 // indirect
23+
github.com/DataDog/go-libddwaf/v4 v4.8.0 // indirect
24+
github.com/DataDog/go-runtime-metrics-internal v0.0.4-0.20250721125240-fdf1ef85b633 // indirect
25+
github.com/DataDog/go-sqllexer v0.1.10 // indirect
26+
github.com/DataDog/go-tuf v1.1.1-0.5.2 // indirect
27+
github.com/DataDog/sketches-go v1.4.7 // indirect
28+
github.com/Microsoft/go-winio v0.6.2 // indirect
29+
github.com/cenkalti/backoff/v5 v5.0.3 // indirect
30+
github.com/cespare/xxhash/v2 v2.3.0 // indirect
31+
github.com/cihub/seelog v0.0.0-20170130134532-f561c5e57575 // indirect
32+
github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc // indirect
33+
github.com/dustin/go-humanize v1.0.1 // indirect
34+
github.com/ebitengine/purego v0.9.1 // indirect
35+
github.com/go-ole/go-ole v1.3.0 // indirect
36+
github.com/golang/protobuf v1.5.4 // indirect
37+
github.com/google/uuid v1.6.0 // indirect
38+
github.com/hashicorp/go-version v1.8.0 // indirect
39+
github.com/json-iterator/go v1.1.12 // indirect
40+
github.com/klauspost/compress v1.18.0 // indirect
41+
github.com/klauspost/cpuid/v2 v2.2.3 // indirect
42+
github.com/linkdata/deadlock v0.5.5 // indirect
43+
github.com/lufia/plan9stats v0.0.0-20250317134145-8bc96cf8fc35 // indirect
44+
github.com/mattn/go-colorable v0.1.13 // indirect
45+
github.com/mattn/go-isatty v0.0.19 // indirect
46+
github.com/minio/simdjson-go v0.4.5 // indirect
47+
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
48+
github.com/modern-go/reflect2 v1.0.3-0.20250322232337-35a7c28c31ee // indirect
49+
github.com/outcaste-io/ristretto v0.2.3 // indirect
50+
github.com/petermattis/goid v0.0.0-20250813065127-a731cc31b4fe // indirect
51+
github.com/philhofer/fwd v1.2.0 // indirect
52+
github.com/pkg/errors v0.9.1 // indirect
53+
github.com/planetscale/vtprotobuf v0.6.1-0.20240319094008-0393e58bdf10 // indirect
54+
github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect
55+
github.com/power-devops/perfstat v0.0.0-20240221224432-82ca36839d55 // indirect
56+
github.com/puzpuzpuz/xsync/v3 v3.5.1 // indirect
57+
github.com/secure-systems-lab/go-securesystemslib v0.9.0 // indirect
58+
github.com/shirou/gopsutil/v4 v4.25.11 // indirect
59+
github.com/tinylib/msgp v1.6.1 // indirect
60+
github.com/tklauser/go-sysconf v0.3.16 // indirect
61+
github.com/tklauser/numcpus v0.11.0 // indirect
62+
github.com/trailofbits/go-mutexasserts v0.0.0-20250514102930-c1f3d2e37561 // indirect
63+
github.com/yusufpapurcu/wmi v1.2.4 // indirect
64+
go.opentelemetry.io/collector/component v1.48.0 // indirect
65+
go.opentelemetry.io/collector/featuregate v1.48.0 // indirect
66+
go.opentelemetry.io/collector/pdata v1.48.0 // indirect
67+
go.opentelemetry.io/collector/pdata/pprofile v0.142.0 // indirect
68+
go.opentelemetry.io/otel v1.39.0 // indirect
69+
go.opentelemetry.io/otel/metric v1.39.0 // indirect
70+
go.opentelemetry.io/otel/trace v1.39.0 // indirect
71+
go.uber.org/atomic v1.11.0 // indirect
72+
go.uber.org/multierr v1.11.0 // indirect
73+
go.uber.org/zap v1.27.1 // indirect
74+
go.yaml.in/yaml/v3 v3.0.4 // indirect
75+
golang.org/x/exp v0.0.0-20251209150349-8475f28825e9 // indirect
76+
golang.org/x/mod v0.31.0 // indirect
77+
golang.org/x/sys v0.39.0 // indirect
78+
golang.org/x/time v0.14.0 // indirect
79+
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 // indirect
80+
google.golang.org/genproto/googleapis/rpc v0.0.0-20251202230838-ff82c1b0f217 // indirect
81+
google.golang.org/protobuf v1.36.10 // indirect
82+
gopkg.in/ini.v1 v1.67.0 // indirect
83+
gopkg.in/yaml.v3 v3.0.1 // indirect
84+
)
85+
86+
replace github.com/DataDog/dd-trace-go/v2 => ../../..

0 commit comments

Comments
 (0)