- docs: update vulnerability reporting process (#442) | @robbkidd
- maint: Update libhoney-go to 1.24.0 (#446) | @MikeGoldsmith
- maint: Update README.md (#441) | @codeboten
- maint(build): add 1.23 to supported versions (#445) | @lizthegrey
- maint(deps): bump golang.org/x/net from 0.20.0 to 0.23.0 (#436) | @dependabot
- maint: bump libhoney-go to v1.23.0 (#439) | @MikeGoldsmith
- maint: Add golang 1.22 to test matrix (#435) | @MikeGoldsmith
Minimum Go version required is 1.19
- maint: drop go 1.18 (#432) | @codeboten
- maint: group patch updates for go deps (#430) | @codeboten
- maint: add labels to release.yml for auto-generated grouping (#426) | @JamieDanielson
- maint(deps): bump the minor-patch group with 4 updates (#431) | @dependabot
- maint(deps): bump the minor-patch group with 1 update (#433) | @dependabot
- feat: support classic Ingest Keys (#421) | @jharley
- maint: update codeowners to pipeline-team (#410) | @JamieDanielson
- maint: update codeowners to pipeline (#409) | @JamieDanielson
- maint(deps): bump google.golang.org/protobuf from 1.31.0 to 1.32.0 (#419) | @dependabot
- maint(deps): bump github.com/google/uuid from 1.5.0 to 1.6.0 (#420) | @dependabot
- maint(deps): bump github.com/DATA-DOG/go-sqlmock from 1.5.0 to 1.5.2 (#417) | @dependabot
- maint(deps): bump github.com/labstack/echo/v4 from 4.11.3 to 4.11.4 (#414) | @dependabot
- maint(deps): bump github.com/google/uuid from 1.4.0 to 1.5.0 (#413) | @dependabot
- perf: speed up adding fields, reduce memalloc if field name is already prefixed with "app." (#406) | @robbkidd
- maint(deps): bump github.com/labstack/echo/v4 from 4.11.1 to 4.11.3 (#403) | @dependabot
- maint(deps): bump golang.org/x/net from 0.12.0 to 0.17.0 (#396) | @dependabot
- maint(deps): bump github.com/google/uuid from 1.3.0 to 1.4.0 (#398) | @dependabot
- maint(deps): bump github.com/felixge/httpsnoop from 1.0.3 to 1.0.4 (#408) | @dependabot
- maint(deps): bump github.com/gorilla/mux from 1.8.0 to 1.8.1 (#407) | @dependabot
Minimum Go version required is 1.18
- maint: drop go 1.17 (#390) | @vreynolds
- ci: move nightly to weekly (#389) | @vreynolds
- maint(deps): bump github.com/labstack/echo/v4 from 4.10.2 to 4.11.1 (#392) | @dependabot
- maint(deps): [examples] bump google.golang.org/protobuf from 1.30.0 to 1.31.0 (#386) | @dependabot
- maint(deps): bump google.golang.org/grpc from 1.55.0 to 1.57.0 (#391) | @dependabot
- maint(deps): bump github.com/gin-gonic/gin from 1.9.0 to 1.9.1 (#382) | @dependabot
- maint(deps): bump github.com/honeycombio/libhoney-go from 1.19.0 to 1.20.0 (#387) | @dependabot
Minimum Go version required is 1.17
- Bump libhoney-go to 1.19.0 (#385) | @MikeGoldsmith
- Bump google.golang.org/grpc from 1.49.0 to 1.55.0 (#380) | @Dependabot
- Bump github.com/stretchr/testify from 1.8.2 to 1.8.4 (#381) | @Dependabot
- Bump github.com/gin-gonic/gin from 1.8.1 to 1.9.0 (#373) | @Dependabot
- Bump github.com/go-sql-driver/mysql from 1.7.0 to 1.7.1 (#379) | @Dependabot
- Bump github.com/stretchr/testify from 1.8.1 to 1.8.2 (#372) | @Dependabot
- Bump github.com/labstack/echo/v4 from 4.9.0 to 4.10.2 (#371) | @Dependabot
- Bump github.com/gobuffalo/pop/v6 from 6.0.8 to 6.1.1 (#368) | @Dependabot
- Bump github.com/stretchr/testify from 1.8.0 to 1.8.1 (#359) | @Dependabot
- Bump github.com/honeycombio/libhoney-go from 1.17.1 to 1.18.0 (#358) | @Dependabot
- Pre-define capacities for rollups and TLFs (#353) | @lizthegrey
- Bump libhoney to 1.17.1 (#355) | @mikegoldsmith
- Add release file (#354) | @vreynolds
- Include Commit/Rollback in db.call names (#345) | @glenjamin
- [maint] Drop support for go 1.16 (#350) | @pkanal
- Bump github.com/honeycombio/libhoney-go from 1.16.0 to 1.17.0 (#347) | @dependabot
- Bump github.com/labstack/echo/v4 from 4.8.0 to 4.9.0 (#346) | @dependabot
- Bump github.com/labstack/echo/v4 from 4.7.2 to 4.8.0 (#343) | @dependabot
- Bump google.golang.org/grpc from 1.48.0 to 1.49.0 (#344) | @dependabot
- Add more request header information to GRPC handler spans (#341) | @robbkidd
request.header.x_forwarded_for
request.header.x_forwarded_proto
request.remote_addr
- maint: add go 1.19 to CI (#340) | @vreynolds
- Downgrade go-sqlite3 to stable version (#338) | @malt3
- Bump google.golang.org/grpc from 1.47.0 to 1.48.0 (#333) | @dependabot
- Bump github.com/gin-gonic/gin from 1.7.7 to 1.8.1 (#330) | @dependabot
- Bump github.com/gobuffalo/pop/v6 from 6.0.4 to 6.0.6 (#335) | @dependabot
- Bump github.com/honeycombio/libhoney-go from 1.15.8 to 1.16.0 (#334) | @dependabot
- Bump github.com/stretchr/testify from 1.7.1 to 1.8.0 (#332) | @dependabot
- [examples] Bump google.golang.org/protobuf from 1.28.0 to 1.28.1 (#336) | @dependabot
- Use simple concat for prepending "app." field prefix (#328) | @lizthegrey
- Bump github.com/gobuffalo/pop/v6 from 6.0.2 to 6.0.4 (#326)
- Bump github.com/felixge/httpsnoop from 1.0.2 to 1.0.3 (#324)
- Bump google.golang.org/grpc from 1.45.0 to 1.47.0 (#325)
- Bump github.com/jmoiron/sqlx from 1.3.4 to 1.3.5 (#321)
- Bump github.com/gobuffalo/pop/v6 from 6.0.1 to 6.0.2 (#323)
Minimum Go version required is now 1.16.
- Update gobuffalo/pop from v5 to v6, which uses features introduced in Go version 1.16.
- Update google.golang.org/protobuf from 1.26.0 to 1.28.0.
- Update google.golang.org/grpc from 1.43.0 to 1.45.0.
- Update labstack/echo from 4.6.1 to 4.7.2.
- Remove support for Go 1.14 and 1.15.
- Add support for Go 1.18.
- Add Environment & Services support (#309) | @JamieDanielson
- feat: pass process root span id as pprof profile id tag (#305) | @lizthegrey
- fix: preserve previous pprof labels after span end (#306) | @lizthegrey
- Add RebindContext method to Tx struct (#303) | @paulosman
- Add a RebindContext method to hnysqlx.DB wrapper (#301) | @paulosman
- Bump google.golang.org/grpc from 1.42.0 to 1.43.0 (#296)
- Bump libhoney-go to v1.15.8 (#297) | @mikegoldsmith
- Add re-triage workflow (#295) | @vreynolds
- accept both w3c and honeycomb propagation headers by default (#293) | @vreynolds
- Bump google.golang.org/grpc from 1.40.0 to 1.42.0 (#288) | @dependabot
- Bump github.com/gin-gonic/gin from 1.7.4 to 1.7.7 (#292) | @dependabot
- [hnygrpc] add a human readable version of the grpc status code to auto instrumentation (#287) | @maplebed
- test: remove flake-prone test case (#289) | @vreynolds
- [sql instrumentation] set name field to db call, not caller (#282) | @maplebed
- update libhoney-go to v1.15.6 (#284)
- empower apply-labels action to apply labels (#283)
- Bump github.com/labstack/echo/v4 from 4.5.0 to 4.6.1 (#276)
- Bump github.com/honeycombio/libhoney-go from 1.15.4 to 1.15.5 (#278)
- Remove dependency on opentelemetry-go (#267) | @paulosman
- Provide more context for sampler test failures (#270) | @vreynolds
- Spruce up CI (#266) | @vreynolds
- add min go verison to readme (#279) | @vreynolds
- Change maintenance badge to maintained (#274) | @JamieDanielson
- Adds Stalebot (#275) | @JamieDanielson
- Add NOTICE (#271) | @cartermp
- Add issue and PR templates (#261) | @vreynolds
- Add OSS lifecycle badge (#260) | @vreynolds
- Add community health files (#259) | @vreynolds
- Bump google.golang.org/grpc from 1.38.0 to 1.40.0 (#263)
- Bump github.com/labstack/echo/v4 from 4.4.0 to 4.5.0 (#264)
- Bump github.com/gin-gonic/gin from 1.7.2 to 1.7.4 (#265)
- Bump go.opentelemetry.io/otel from 1.0.0-RC1 to 1.0.0-RC2 (#256)
- Update libhoney from 1.15.3 to 1.15.4 (#253)
- Bump github.com/labstack/echo/v4 from 4.3.0 to 4.4.0 (#251)
- Bump github.com/google/uuid from 1.2.0 to 1.3.0 (#250)
- feat: span.AddField() support adding error (#246)
- Avoid hnynethttp.WrapHandler panic with non-pointer handlers (#92)
- fix(echo): this change ensures honeycomb captures errors correctly (#249)
- Use PingContext in the wrapped PingContext method (#245)
- Bump go.opentelemetry.io/contrib/propagators from 0.20.0 to 0.21.0 (#237)
- Bump github.com/honeycombio/libhoney-go from 1.15.2 to 1.15.3 (#236)
- Updates Github Action Workflows (#243)
- Updates Dependabot Config (#240)
- Switches CODEOWNERS to telemetry-team (#239)
- Bump github.com/gin-gonic/gin from 1.7.1 to 1.7.2 (#234)
- Bump github.com/felixge/httpsnoop from 1.0.1 to 1.0.2 (#233)
- Bump go.opentelemetry.io/contrib/propagators from 0.19.0 to 0.20.0 (#232)
- Bump go.opentelemetry.io/otel from 0.19.0 to 0.20.0 (#232)
- Bump go.opentelemetry.io/otel/trace from 0.19.0 to 0.20.0 (#232)
- Add missing go.sum entry, which caused issues with go 1.16+ builds (#227) | @vreynolds
- Add gRPC UnaryClientInterceptor which includes trace context in the outgoing request metadata (#217) | @aarongable
- Capture request.host property on http client redirects (#216) | @mccutchen
- Bump github.com/labstack/echo/v4 from 4.2.1 to 4.3.0 (#218)
- Bump github.com/gin-gonic/gin from 1.6.3 to 1.7.1 (#213)
- Bump github.com/jmoiron/sqlx from 1.3.1 to 1.3.4 (#221)
- trace.NewTrace now takes *propagation.PropagationContext instead of serialized headers (#209)
- You can still use trace.NewTraceFromSerializedHeaders to ease migration
- propagation.Propagation: use propagation.PropagationContext (#209)
- propagation.MarshalTraceContext: use propagation.MarshalHoneycombTraceContext (#209)
- propagation.UnmarshalTraceContext: use propagation.UnmarshalHoneycombTraceContext (#209)
- propagation.UnmarshalTraceContextV1: use propagation.UnmarshalHoneycombTraceContext (#209)
- trace.NewTraceFromPropagationContext: use trace.NewTrace instead (#209)
- Set additional response header values in hnygorilla wrapper (#196) | @nathancoleman
- Bump go.opentelemetry.io/otel from 0.15.0 to 0.19.0 (#179) (#208)
- Bump go.opentelemetry.io/contrib/propagators from 0.15.1 to 0.18.0 (#180) (#193) (#200)
- Bump github.com/go-sql-driver/mysql from 1.5.0 to 1.6.0 (#204)
- Bump google.golang.org/grpc from 1.27.0 to 1.36.1 (#178) (#203)
- Bump github.com/labstack/echo/v4 from 4.1.17 to 4.2.1 (#194)
- Bump github.com/jmoiron/sqlx from 1.2.0 to 1.3.1 (#188)
- Bump github.com/google/uuid from 1.1.4 to 1.2.0 (#186)
- Bump github.com/honeycombio/libhoney-go from 1.15.0 to 1.15.2 (#183)
- Bump github.com/google/uuid from 1.1.2 to 1.1.4 (#171, #174)
- Ensure rollup fields are included on subroot spans (#173) | @BRMatt
- Default the w3c propagation header sampled flag to
01
(#176)
- Add hnygrpc package including support for gRPC interceptor wrapping. (#169)
- Bump otel dependencies from 0.13.0 to 0.15.1
- Bump github.com/honeycombio/libhoney-go from 0.14.1 to 0.15.0
- Write keys / API keys will now be masked in debug / console logs.
- Add GitHub release publish step (#159)
- Bump go.opentelemetry.io/contrib/propagators from 0.12.0 to 0.13.0 (#156)
- Bump github.com/gobuffalo/pop/v5 from 5.2.4 to 5.3.1 (#155)
- Add DB.BindNamed to hnysql wrapper (#157) | @matiasanaya
- Implemented B3 Propagator (#146) Thanks @Wilhansen!
- Add .editorconfig to help provide consistent IDE styling (#143)
- Update dependencies
- Add extra warnings when enabling STDOUT (#134)
- Add log when event is rejected with invalid api key (#135)
- Upgrade dependencies
- Fixing some flaky tests
- Protection from potential data race condition in propagation context generating code.
- Calling IsValid() on Honeycomb header unmarshal was preventing manual creation of trace from PropagationContext. Only verify that trace_id is provided whenever parent_id is.
- Generated Span and Trace IDs have changed from UUID4 strings to 16 and 32 character hex encoded strings. These are compatible with the W3C Trace Context specification.
- Auto-instrumentation support for Gingonic applications (thank you @Nalum!)
- Marshal / unmarshal functions for Amazon load balancer trace headers and W3C Trace Context headers (used by OpenTelemetry).
- The hnynethttp package now supports configurable hooks for parsing trace context headers from incoming HTTP requests and injecting trace context headers in outgoing HTTP requests
- Added content encoding field to
hnynethttp
responses. - Added context methods to
hnypop.DB
. Now working with latest version ofpop
.
- Added getter methods for trace and span IDs and parent IDs.
- Added response content-type and content-length to the automatic instrumentation for HTTP spans.
- Add additional go database stats to
hnysql
andhnysqlx
wrapppers. In go 1.11 and later, we additionally reportdb.conns_in_use
,db.conns_idle
,db.wait_count
, anddb.wait_duration
. See https://golang.org/pkg/database/sql/#DB.Stats
- added missing
Close
function to theStmt
type - renamed
echo
example binary for using the echo web framework so it doesn't collide with the builtin shellecho
command - updated transaction's
QueryxContext
to use a span instead of an event
- Fixed
db.error
not being added byhnysql
andhnysqlx
wrappers. - Reduction in heap allocations when creating a span.
- Fixed an issue where the libhoney transmission was being spun up without a default batch timeout, so spans were only getting sent when they hit the batch max (50) rather than after a 100ms timeout.
- Use libhoney defaults for all missing parameters during initialization (previously the beeline had a few values that differed from the libhoney defaults).
- Added the Contributors file listing people that have made contributions to the Beeline
- Fix race condition when concurrently adding children and sending a non-root span. Contribution by @carlosgaldino
- @jamietsao contributed middleware for the Echo router (https://echo.labstack.com/)
- Events that were coming in with an existing sample rate to a beeline configured to do additional sampling were not computing the final sample rate correctly. This change fixes the sample rate in that specific case.
- Added missing comment describing the semantics of the
dataset
field in the trace propagation header added in v0.3.5
- Sample rate returned by the sampler hook was incorrectly being multiplied with the default global sample rate.
- Add a
libhoney.Client
as a configurable item in the beeline initial config. This allows full control over the underlying transmission of spans, so you can replace the HTTP transport or adjust queue sizes and so on
- Add
CopyContext
function to simplify moving trace metadata to a new context (for example, when trying to avoid a cancellation in an async span). - Improve handling of broken or partial trace propagation headers
- Add
dataset
to serialized trace headers to allow one service with multiple upstream callers to send spans to the right destination dataset
- Delete spans from the trace when they're sent for improved memory management
- Add a benchmark
- Add URL queries and add name even when empty
- Fix race condition on map access that can occur with Sampler and Presend hooks when AddField is called concurrently with Send.
NewResponseWriter
no longer returns a concrete type directly usable as anhttp.ResponseWriter
. It now exposes the wrappedhttp.ResponseWriter
through the fieldWrapped
.
Code that would have previously looked like:
wrappedWriter := common.NewResponseWriter(w)
handler.ServeHTTP(wrappedWriter, r)
now looks like:
wrappedWriter := common.NewResponseWriter(w)
handler.ServeHTTP(wrappedWriter.Wrapped, r)
- Allow override of MaxConcurrentBatches, MaxBatchSize, and PendingWorkCapacity in
beeline.Config
- Sets default value for MaxConcurrentBatches to 20 (from 80), and PendingWorkCapacity to 1000 (from 10000).
- rollup fields were not getting the rolled up values added to the root span
- sql and sqlx wrappers get both the DB call being made (eg Select) as well as the name of the function making the call (eg FetchThingsByID)
- fix version number inconsistency with a patch bump
- fix propagation bug when an incoming request has a serialized beeline trace header
This is the second major release of the beeline. It changes the model from "one current span" to a to a doubly-linked tree of events (now dubbed "spans") representing a trace.
- introduces the concept of a span
- adds functions to create new spans in a trace and add fields to specific spans
- adds the ability to create and accept a serialized chunk of data from an upstream service to connect in-process traces in a distributed infrastructure into one large trace.
- adds trace level fields that get copied to every downstream span
- adds rollup fields that sum their values and push them in to the root span
- adds a pre-send hook to modify spans before sending them to Honeycomb
- adds trace-aware deterministic sampling as the default
- adds a sampler hook to manually manage sampling if necessary
- removed
ContextEvent
andContextWithEvent
functions; replaced by spans
- augment the net/http wrapper to wrap
RoundTripper
s and handle outbound HTTP calls - adding a wrapper for the
pop
package
- add new sqlx functions to add context to transactions and rollbacks
- add HTTP Headers X-Forwarded-For and X-Forwarded-Proto to events if they exist
- use the passed in context in sqlx instead of creating a background context
- Use the right Host header for incoming HTTP requests
- Recognize struct HTTP handlers and add their name
- Fix nil route bug
Initial Release