oteps VS b3-propagation

Compare oteps vs b3-propagation and see what are their differences.

oteps

OpenTelemetry Enhancement Proposals (by open-telemetry)

b3-propagation

Repository that describes and sometimes implements B3 propagation (by openzipkin)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
oteps b3-propagation
4 3
316 516
1.9% 1.7%
5.3 2.7
9 days ago 2 months ago
Makefile
Apache License 2.0 Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

oteps

Posts with mentions or reviews of oteps. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-08-28.
  • OpenTelemetry in 2023
    36 projects | news.ycombinator.com | 28 Aug 2023
    Oh nice, thank you (and also solumos) for the links! It looks like oteps/pull/171 (merged June 2023) expanded and superseded the opentelemetry-proto/pull/346 PR (closed Jul 2022) [0]. The former resulted in merging OpenTelemetry Enhancement Proposal 156 [1], with some interesting results especially for 'Phase 2' where they implemented columnar storage end-to-end (see the Validation section [2]):

    * For univariate time series, OTel Arrow is 2 to 2.5 better in terms of bandwidth reduction ... and the end-to-end speed is 3.1 to 11.2 times faster

    * For multivariate time series, OTel Arrow is 3 to 7 times better in terms of bandwidth reduction ... Phase 2 has [not yet] been .. estimated but similar results are expected.

    * For logs, OTel Arrow is 1.6 to 2 times better in terms of bandwidth reduction ... and the end-to-end speed is 2.3 to 4.86 times faster

    * For traces, OTel Arrow is 1.7 to 2.8 times better in terms of bandwidth reduction ... and the end-to-end speed is 3.37 to 6.16 times faster

    [0]: https://github.com/open-telemetry/opentelemetry-proto/pull/3...

    [1]: https://github.com/open-telemetry/oteps/blob/main/text/0156-...

    [2]: https://github.com/open-telemetry/oteps/blob/main/text/0156-...

  • Grafana Phlare, open source database for continuous profiling at scale
    8 projects | news.ycombinator.com | 2 Nov 2022
    https://github.com/open-telemetry/oteps/issues/139

    It takes a lot of time and effort to bake a cross-vendor cross-language standard.

  • Faster Protocol Buffers
    5 projects | news.ycombinator.com | 14 Aug 2022
    This. The statelessness of the OTLP is by design. I did consider stateful designs with e.g. shared state dictionary compression but eventually chose not to, so that the intermediaries can remain stateless.

    An extension to OTLP that uses shared state (and columnar encoding) to achieve more compact representation and is suitable for the last network leg in the data delivery path has been proposed and may become a reality in the future: https://github.com/open-telemetry/oteps/pull/171

b3-propagation

Posts with mentions or reviews of b3-propagation. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-08-28.
  • OpenTelemetry in 2023
    36 projects | news.ycombinator.com | 28 Aug 2023
    I've been playing with OTEL for a while, with a few backends like Jaeger and Zipkin, and am trying to figure out a way to perform end to end timing measurements across a graph of services triggered by any of several events.

    Consider this scenario: There is a collection of services that talk to one another, and not all use HTTP. Say agent A0 makes a connection to agent A1, this is observed by service S0 which triggers service S1 to make calls to S2 and S3, which propagate elsewhere and return answers.

    If we limit the scope of this problem to services explicitly making HTTP calls to other services, we can easily use the Propagators API [1] and use X-B3 headers [2] to propagate the trace context (trace ID, span ID, parent span ID) across this graph, from the origin through to the destination and back. This allows me to query the metrics collector (Jaeger or Zipkin) using this trace ID, look at the timestamps originating at the various services and do a T_end - T_start to determine the overall time taken by one call for a round trip across all the related services.

    However, this breaks when a subset of these functions cannot propagate the B3 trace IDs for various reasons (e.g., a service is watching a specific state and acts when the state changes). I've been looking into OTEL and other related non-OTEL ways to capture metrics, but it appears there's not much research into this area though it does not seem like a unique or new problem.

    Has anyone here looked at this scenario, and have you had any luck with OTEL or other mechanisms to get results?

    [1] https://opentelemetry.io/docs/specs/otel/context/api-propaga...

    [2] https://github.com/openzipkin/b3-propagation

    [3] https://www.w3.org/TR/trace-context/

  • OpenTelemetry and Istio: Everything you need to know
    3 projects | dev.to | 3 Feb 2022
    (Note that OpenTelemetry uses, by default, the W3C context propagation specification, while Istio uses the B3 context propagation specification – this can be modified).
  • Spring Cloud Sleuth in action
    6 projects | dev.to | 4 Mar 2021
    The default format for context propagation is B3 so we use headers X-B3-TraceId and X-B3-SpanId

What are some alternatives?

When comparing oteps and b3-propagation you can also consider the following projects:

zipkin-api - Zipkin's language independent model and HTTP Api Definitions

trace-context-w3c - W3C Trace Context purpose of and what kind of problem it came to solve.

odigos - Distributed tracing without code changes. 🚀 Instantly monitor any application using OpenTelemetry and eBPF

zipkin - Zipkin is a distributed tracing system

exp-lazyproto - Experimental fast implementation of Protobufs in Go

spring-cloud-sleuth-in-action - 🍀 Spring Cloud Sleuth in Action

community - OpenTelemetry community content

terraform-aws-jaeger - Terraform module for Jeager

protobuf-flatbuffer-benchmark