veneur VS b3-propagation

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

veneur

A distributed, fault-tolerant pipeline for observability data (by stripe)

b3-propagation

Repository that describes and sometimes implements B3 propagation (by openzipkin)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
veneur b3-propagation
2 3
1,714 516
0.1% 0.6%
3.5 2.7
about 1 month ago 2 months ago
Go
MIT License 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.

veneur

Posts with mentions or reviews of veneur. 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
    This was the idea behind Stripe's Veneur project - spans, logs, and metrics all in the same format, "automatically" rolling up cardinality as needed - which I thought was cool but also that it would be very hard to get non-SRE developers on board with when I saw a talk about it a few years ago.

    https://github.com/stripe/veneur

  • Launch HN: Opstrace (YC S19) – open-source Datadog
    11 projects | news.ycombinator.com | 1 Feb 2021
    One pain point with Prometheus is that is has relatively weak support for quantiles, histograms, and sets[1]:

    - Histograms require manually specifying the distribution of your data, which is time-consuming, lossy, and can introduce significant error bands around your quantile estimates.

    - Quantiles calculated via the Prometheus "summary" feature are specific to a given host, and not aggregatable, which is almost never what you want (you normally want to see e.g. the 95th percentile value of request latency for all servers of a given type, or all servers within a region). Quantiles can be calculated from histograms instead, but that requires a well-specified histogram and can be expensive at query time.

    - As far as I know, Prometheus doesn't have any explicit support for unique sets. You can compute this at query time, but persisting and then querying high-cardinality data in this way is expensive.

    Understanding the distribution of your data (rather than just averages) is arguably the most important feature you want from a monitoring dashboard, so the weak support for quantiles is very limiting.

    Veneur[2] addresses these use-cases for applications that use DogStatsD[3] by using clever data structures for approximate histograms[4] and approximate sets[5], but I believe its integration with Prometheus is limited and currently only one-way - there is a CLI app to poll Prometheus metrics and push them into Veneur, but there's no output sink for Veneur to write to Prometheus (or expose metrics for a Prometheus instance to poll).

    It would be extremely useful to have something similar for Prometheus, either by integrating with Veneur or implementing those data structures as an extension to Prometheus.

    [1] https://prometheus.io/docs/practices/histograms/

    [2] https://github.com/stripe/veneur

    [3] https://docs.datadoghq.com/developers/dogstatsd/

    [4] https://github.com/stripe/veneur#approximate-histograms

    [5] https://github.com/stripe/veneur#approximate-sets

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 veneur and b3-propagation you can also consider the following projects:

opstrace - The Open Source Observability Distribution

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

cortex - A horizontally scalable, highly available, multi-tenant, long term Prometheus.

zipkin - Zipkin is a distributed tracing system

Cortex - Cortex: a Powerful Observable Analysis and Active Response Engine

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

loki - Like Prometheus, but for logs.

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

influxdb-apply - Define InfluxDB users and databases with a yaml file.

community - OpenTelemetry community content

skywalking - APM, Application Performance Monitoring System

oteps - OpenTelemetry Enhancement Proposals