Releases: DataDog/dd-trace-go
1.30.0
This change comes packed with features and new integrations thanks to all the nice contributions, along with a few fixes.
Upgrades
⚠️ Users of the profiler that callprofiler.WithAPIKey()
or set aDD_API_KEY
environment variable will see a change in behaviour which could result in breaking their profiling integration. Profiles will now be uploaded through the agent running onlocalhost:8126
. If you don't have an agent running there, please useprofiler.WithAgentAddr()
or the appropriate environment variables to configure the location of the agent. This commit has more details on the exact changes.
Features
- internal: add support for Fargate 1.4 (#863)
- contrib/gorilla/mux: add WithQueryParams and WithHeaderTags (#825)
- contrib/go-chi/chi.v5: support go-chi/chi/v5 (#858) /thanks @johejo
- contrib/confluentinc/confluent-kafka-go: add tracing for ReadMessage method (#880) /thanks @alebabai
- profiler: Implement WithUploadTimeout (#852)
- ddtrace/tracer: improve stack trace generation performance (#884)
- contrib/go-redis/redis.v7: support for redis v7 package (#862)
- ddtrace/tracer: improve Lamba performance (#898)
- contrib/net/http: add Unwrap method for RoundTripper (#903) /thanks @bullgare
- ddtrace/opentracer: add support for opentracing.TracerContextWithSpan Extension (#855) /thanks @shannontan-bolt
- ddtrace/opentracer: consider FollowsFrom references as children (#905) /thanks @shannontan-bolt
- contrib/database/sql.tracedConn implement driver.SessionResetter (#908) /thanks @kyfk
Fixes
- contrib/globalsign/mgo: fix infinite loop (#874)
- profiler: fix newlines breaking up log messages (#891)
- ddtrace/tracer: follow noDebugStack setting when using SetTag with an error (#900)
- contrib/Shopify/sarama: fix possible deadlock in WrapAsyncProducer (#907) /thanks @pellared
To view all changes check out new commits and the 1.30.0 milestone.
1.29.2
1.29.1
1.29.0
This release contains a bunch of new features and fixes. Thank you to everyone who helped us by contributing both new features and bug fixes ❤️
Features
- ddtracer/tracer: add support for DD_TRACE_SOURCE_HOSTNAME (#839)
- all: improve debug logging (#816)
- profiler: add options for block and mutex rates (#814)
- contrib/go-redis/redis.v8: add support for WrapClient (#808) (Thanks @seancaffery)
- contrib/jinzhu/gorm: add WithErrorCheck option (#806) (Thanks @moonsub-kim)
- profiler: add support for v3 upload and metrics (#781)
- contrib/gorm.io/gorm.v1: add support for gorm@v1 (#759)
- ddtrace/tracer: fmt.Stringer in span.SetTag (#799) (Thanks @pierrre)
- ddtracer/tracer: ensure tag keys are unique across metrics and meta tags (#800)
- contrib/gorilla/mux: add option for skipping certain requests (#789) (Thanks @stroem)
- contrib/gofiber/fiber.v2: add integration for Fiber v2 framework (#786) (Thanks @andrei-dascalu)
- {profiler,ddtrace/tracer}: add UDS client options (#788)
Fixes
- ddtracer/tracer: fix an issue with illegal characters in Lambda mode (#832)
- profiler: fix goroutineswait profile frame order (#850)
- contrib.confluent-kafka-go: use github.com import path (#847)
- ddtrace/tracer: updated DD_TAGS parsing to support space separation (#837)
- ddtrace/tracer: B3 headers are now encoded as exactly 16 character long (#817)
- profiler: Start() doesn't unlock mutex on error (#819)
- ddtrace/tracer: improve "Tracing Without Limits" sampling rates (#812)
- contrib/aws/aws-sdk-go: open only a single span for retryable operations (#777) (Thanks @marcind)
Upgrades
- profiler: increase DefaultBlockRate from 100 to 10000 (#836)
To view all changes check out new commits and the 1.29.0 milestone.
1.28.0
This release has a lot of little features and new integrations for go-pg and go-redis v8. It also includes a number of bug fixes and other minor improvements. 🚀
Thanks again to all contributors!
Features
- contrib/go-redis/redis.v8: support go-redis.v8 (#727) (Thanks @sfroment)
- contrib/jmoiron/sqlx: allow adding sqltrace.Option to Open (#762)
- contrib/go-pg/pg.v10: add support for github.com/go-pg/pg/v10 (#686) (Thanks @patriczek)
- ddtrace/tracer: add freebsd osinfo support (#766) (Thanks @vanillahsu)
- contrib/cloud.google.com/go/pubsub.v1: Add WithServiceName option (#757) (Thanks @mickeyreiss)
- ddtrace/tracer: Improve agent performance by marking top level spans (#782, #784)
- contrib/gin-gonic/gin: support globalconfig.ServiceName() (#776) (Thanks @marcind)
- contrib/go-chi/chi: Added option to set custom error status check (#773) (Thanks @Hunrik)
Fixes
- contrib/go-chi/chi: Handle 0 status code correctly (#740) (Thanks @adw1n)
- Use existing const in osinfo_default (#754) (Thanks @aeneasr)
- contrib/Shopify/sarama: use sarama.MinVersion in tests. (#761)
- profiler: set profiler upload timeout to 10s (#768)
- ddtrace/tracer: StartSpanFromContext should work nil ctx on Go 1.15 (#749)
- contrib/Shopify/sarama: Fix WrapAsyncProducer tracing support (#738) (Thanks @adw1n)
- ddtrace/tracer: allow B3 trace IDs longer than 16 chars (#780) (Thanks @stroem)
To view all changes check out new commits and the 1.28.0 milestone.
1.27.1
1.27.0
This release has a lot of new features including a new integration for cloud.google.com/go/pubsub
, new configuration options, and support for tracing in AWS Lambda environments, as well as a number of fixes.
This release is especially notable for its high number of community contributions. Thanks again to all contributors. 🥇
Features
- contrib/database/sql: add sql.query_type tag to sql spans (#707) (Thanks, @speza)
- contrib/gopkg.in/jinzhu/gorm.v1: add support for new path (#713) (Thanks, @patronmike)
- contrib/graph-gophers/graphql-go: Add WithOmitTrivial option. (#715) (Thanks, @cube2222)
- contrib/jinzhu/gorm: Add custom tags. (#723) (Thanks, @cube2222)
- profiler: add API key check at initialization of Profiler object (#718)
- contrib: add support for cloud.google.com/go/pubsub (#721) (Thanks, @CAFxX)
- ddtrace/tracer: add support for lambda tracing (#702, #742)
- contrib/go-redis/redis: Enable tracing of Pipelined and TxPipelined (#724) (Thanks, @JDiPierro)
- ddtrace/tracer: add WithDebugStack StartOption to configure stack traces. (#739)
Fixes
- contrib/gomodule/redigo: Don't pass nil contexts around in withSpan (#711) (Thanks, @abustany)
- ddtrace/tracer: improve agent connectivity check (#719)
- contrib/garyburd/redigo: support go 1.15 (#731) (Thanks, @lbcjbb)
- contrib/net/http: Add error to span in round tripper (#736) (Thanks, @marciorodrigues87)
- contrib/twitchtv/twirp: Add explicit reference to the request span (#726) (Thanks, @mickeyreiss)
To view all changes check out new commits and the 1.27.0 milestone.
1.26.0
This release is full of little improvements. 🥳
It incorporates additional support for configuration through environment variables, improved debugging capability through startup logging, support for labstack/echo@v4 as well as various other improvements.
Features
- ddtrace/tracer: pick up env, version, service from DD_TAGS (#675)
- contrib/net/http: add support for resource name customization with WrapClient (#690) (Thanks, @ichizero)
- ddtrace/tracer: add startup logging (#685)
- profiler: add goroutine profile type (#693)
- all: add runtime-id to profiler and tracer global tags. (#692)
- contrib/labstack/echo.v4: add support for echo@v4 (#698)
- ddtrace/tracer: add support for various environment variables (#696, #691)
Fixes
- contrib/go.mongodb.org/mongo-driver: set span type to "mongodb" (#683)
To view all changes check out new commits and the 1.26.0 milestone.
1.25.0
This release incorporates support for Go modules, additional options for the profiler, improved support for log injection, and various improvements and fixes for the contrib packages.
Upgrade Notes
- Users of our
contrib/shopify/sarama
integration will need to change the import path fromgopkg.in/Shopify/sarama.v1
togithub.com/Shopify/sarama
if they have not already done so. This is the result ofgithub.com/Shopify/sarama
using the github path as their canonical name in theirgo.mod
file. Please see (IBM/sarama#1510) and (#672) for more details.
Features
- profiler: add WithSite option and DD_SITE environment variable. (#644)
- ddtrace/tracer: improve support for log injection (#657, #676)
- contrib/internal/httputil: add HTTP host tag (#648)
- contrib/google.golang.org/grpc: add metadata and request parameter tags for grpc calls (#647) (Thanks, @mingrammer)
- contrib/jinzhu/gorm: add context getter for gorm.db (#667) (Thanks, @zhammer)
- all: migrate to modules (#672)
- ddtrace/tracer: send all global tags with metrics (#673) (Thanks, @DarrenTsung)
- profiler: support agent-based deployments and have those as default. (#668)
Fixes
To view all changes check out new commits and the 1.25.0 milestone.
1.24.1
This release removes the WithValueTags
option from the contrib/bradfitz/gomemcache
integration.
WithValueTags
could be problematic for multiple reasons such as producing unexpectedly large quantities of data, and possible security issues. We do not want to provide APIs with unexpected or potentially dangerous behavior.