Protobuf.NET VS dapr

Compare Protobuf.NET vs dapr and see what are their differences.

Protobuf.NET

Protocol Buffers library for idiomatic .NET (by protobuf-net)

dapr

Dapr is a portable, event-driven, runtime for building distributed applications across cloud and edge. (by dapr)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
Protobuf.NET dapr
10 79
4,525 23,293
1.5% 1.3%
6.2 9.7
6 days ago 4 days ago
C# Go
GNU General Public License v3.0 or later 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.

Protobuf.NET

Posts with mentions or reviews of Protobuf.NET. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-02-09.
  • ProtoBuf message serialization in Akka.NET using protobuf-net
    2 projects | dev.to | 9 Feb 2023
    This article requires that reader is familar with core concept of Akka.NET serialization (see https://getakka.net/articles/serialization/serialization.html) and ProtoBuf-Net library (see https://github.com/protobuf-net/protobuf-net).
  • Auto-Incrementing Sequences
    2 projects | dev.to | 8 Jan 2023
    The model used, a simple invoice which uses protobuf-net 1 NuGet package to store information in a binary file.
  • A .NET source generator for generating object mappings. Trimming save and fast. Inspired by MapStruct.
    3 projects | /r/programming | 28 Feb 2022
    Not sure if it works with gRPC but I really like how Protobuf.NET uses attributes like other serializers instead of needing to write a .proto and generate (not-very-C#-friendly) classes from it. Well, until you need to interop with other languages.
  • Practice resources for handling and optimizing large game data sets?
    3 projects | /r/Unity3D | 1 Feb 2022
    I mentioned JSON, but there are many formats that are much more efficient. I can mention FlatBuffers, MessagePack and ProtoBuf. These are the ones I've used myself, and personally I'm most comfortable with MessagePack and ProtoBuf. I don't think the performance would be an issue if you had to choose between these three, it's mostly the API that is different.
  • Automatically generate proxy services for blazor wasm+asp.net core?
    1 project | /r/Blazor | 27 Jan 2022
    The closest way would be using Grpc.Web + Protobuf.net. The overall experience is pretty close to WCF server + Client where you share a common interface and let the client and server just call through those.
  • gRPC Development experience in modern .NET
    7 projects | /r/dotnet | 12 Nov 2021
    Grpc Web with Blazor WASM is a really pleasant experience so far imo for my personal projects at home. You have strongly typed models and methods and you have choice on sharing the contract between client and server if you're using code first instead of proto IDL files (e.g. protobuf-net).
  • What is your preferred way of creating application specific files for a local application?
    3 projects | /r/csharp | 4 Sep 2021
  • Integrating Apollo Studio with GraphQL for .NET - Part 2
    2 projects | dev.to | 28 May 2021
    It's pretty straight-forward to follow the protobuf-net docs to serialize the report, but we should really GZIP the stream for sending to reduce bandwidth consumption and improve performance:
  • Integrating Apollo Studio with GraphQL for .NET - Part 1
    2 projects | dev.to | 27 May 2021
    There are a number of Protobuf implementations for .NET Core, but I like protobuf-net as it's a nice, clean, Apache 2.0 Licensed implementation. It is also supported by protogen, a great online generator that will output protobuf-net classes ready for use (for its CSharp profile). If you open the latest schema from the link here, you can simply paste into the generator. NOTE: At the time of writing, [(js_preEncoded)=true] isn't supported by the generator, and can be removed from the proto schema.
  • Don't Use Protobuf for Telemetry
    8 projects | news.ycombinator.com | 30 Dec 2020
    > Protobuf-java is a little heavy [...] Just depending on the library adds 1.6MB and nearly 700 classes before you even generate your own message classes.

    By comparison, protobuf-net [1] is about 260KB and 68 classes. Python's [2] is a 1MB package download (with source).

    Why's the Java one so big?

    [1] https://github.com/protobuf-net/protobuf-net

    [2] https://pypi.org/project/protobuf

dapr

Posts with mentions or reviews of dapr. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-08.
  • Dapr: Microservices API
    1 project | news.ycombinator.com | 24 Apr 2024
  • Interesting projects using WebAssembly
    4 projects | dev.to | 8 Apr 2024
    The following two examples are open-source projects maintained by Fermyon with contributions from companies like Microsoft and SUSE. The first is Spin, which allows us to use WebAssembly to create Serverless applications. The second, SpinKube, combines some of the topics I'm most excited about these days: WebAssembly and Kubernetes Operators :) The official website says, "By running applications in the Wasm abstraction layer, SpinKube offers developers a more powerful, efficient, and scalable way to optimize application delivery on Kubernetes." By the way, this post shows how to integrate SpinKube with Dapr, another technology I'm very interested in, and I should write some posts soon.
  • The Ambassador Pattern
    1 project | news.ycombinator.com | 25 Nov 2023
    Speaking of this has anyone had much experience with Dapr (https://dapr.io/) before?

    I always thought this was a particularly interesting approach from Microsoft where they use this pattern to essentially take the complexity of micro services and instead try and keep it as simple as a normal .NET application but (and I think this is the clever part) in both a vendor and language neutral way.

    But all of a sudden it means you can start removing all kinds of cruft and random SDKs from your codebase and push almost all of your interactions with the outside world into something like this .

  • Comparing Azure Functions vs Dapr on Azure Container Apps
    3 projects | dev.to | 9 Oct 2023
    Azure Container Apps hosting of Azure Functions is a way to host Azure Functions directly in Container Apps - additionally to App Service with and without containers. This offering also adds some Container Apps built-in capabilities like the Dapr microservices framework which would allow for mixing microservices workloads on the same environment with Functions.
  • Episode 150: myNewsWrap – SAP and Microsoft
    3 projects | dev.to | 16 Sep 2023
    Having containers is nice but everything (well ... nearly everything 😉) gets better with Dapr as an outstanding tool for app development in the container-based area. Here we go what might be worth a look:
  • Using DARP in production?
    1 project | /r/microservices | 9 Sep 2023
    Anyone using or planing to use darp Distributed application platform runtime as a microservices platform? https://dapr.io/
  • Ensuring Seamless Operations: Troubleshooting and Resolving Dapr Certificate Expiry
    2 projects | dev.to | 20 Jul 2023
    A CNCF project, the Distributed Application Runtime (Dapr) provides APIs that simplify microservice connectivity. Whether your communication pattern is service to service invocation or pub/sub messaging, Dapr helps you write resilient and secured microservices. Essentially, it provides a new way to build microservices by using the reusable blocks implemented as sidecars.
  • Understanding the Dapr workflow engine and workflow patterns in .NET (1hr webinar)
    1 project | /r/dotnet | 2 Jun 2023
    Dapr is a runtime that implements common patterns such as pub/sub, state storage, etc. It runs as a sidecar to your app. Your app then interfaces with it using an sdk or http calls to use said patterns instead of implementing those patterns directly yourself. Seems pretty cool to me, but you can find out more at https://dapr.io/.
  • Is Dapr actually used by anyone?
    1 project | /r/dotnet | 2 Jun 2023
    - Over 21k stars on GitHub, see the core repo and devstats.
  • Modular Architecture Design question | Re-using modules in multiple applications
    3 projects | /r/csharp | 17 May 2023
    I would like to build modules, either in a modular monolith style, or in a microservice style using DAPR and/or Tye.

What are some alternatives?

When comparing Protobuf.NET and dapr you can also consider the following projects:

Protobuf - Protocol Buffers - Google's data interchange format

MassTransit - Distributed Application Framework for .NET

MessagePack for C# (.NET, .NET Core, Unity, Xamarin) - Extremely Fast MessagePack Serializer for C#(.NET, .NET Core, Unity, Xamarin). / msgpack.org[C#]

camel-k - Apache Camel K is a lightweight integration platform, born on Kubernetes, with serverless superpowers

Json.NET - Json.NET is a popular high-performance JSON framework for .NET

tye - Tye is a tool that makes developing, testing, and deploying microservices and distributed applications easier. Project Tye includes a local orchestrator to make developing microservices easier and the ability to deploy microservices to Kubernetes with minimal configuration.

ZeroFormatter - Infinitely Fast Deserializer for .NET, .NET Core and Unity.

OpenFaaS - OpenFaaS - Serverless Functions Made Simple

Msgpack-Cli - MessagePack implementation for Common Language Infrastructure / msgpack.org[C#]

Nomad - Nomad is an easy-to-use, flexible, and performant workload orchestrator that can deploy a mix of microservice, batch, containerized, and non-containerized applications. Nomad is easy to operate and scale and has native Consul and Vault integrations.

Utf8Json - Definitely Fastest and Zero Allocation JSON Serializer for C#(NET, .NET Core, Unity, Xamarin).

NServiceBus - Build, version, and monitor better microservices with the most powerful service platform for .NET