asio-grpc VS libunifex

Compare asio-grpc vs libunifex and see what are their differences.

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
asio-grpc libunifex
4 22
325 1,366
- 2.5%
9.0 7.6
2 days ago 8 days ago
C++ C++
Apache License 2.0 GNU General Public License v3.0 or later
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.

asio-grpc

Posts with mentions or reviews of asio-grpc. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-09-14.
  • Generate gRPC source files using CMake
    5 projects | /r/cpp | 14 Sep 2022
    Since I can never remember what arguments to pass to protobuf_generate to create Protobuf and gRPC source files, I wrote an article about it. It provides a copy-paste-able code snippet along with an explanation of all arguments that protobuf_generate accepts, how to format it nicely using cmake-format and how to make things easier with asio-grpc.
  • Using Asio for asynchronous gRPC clients and servers
    3 projects | /r/cpp | 6 Jun 2022
    Asio-grpc makes exactly that possible by providing an Asio execution_context compatible interface to the CompletionQueue. It supports all types of RPCs (including generic ones), completion tokens, cancellation, as well as libunifex sender/receiver (if you want to try out what might become std::execution). The latest release (v1.7.0) also introduced a GrpcStream class for writing Rust/Golang select-style code.
  • DevBlog #1 - Poseidon
    1 project | /r/WarsawRevamped | 5 Apr 2022
    It hasn't been without issue, however. Problems that may lie in official google-maintained libraries are of course present and required design changes, and I was even prompted to write my own bitset library that outperforms the C++ standard's by a factor of 60. Madness. Right?
  • C++20 coroutines for asynchronous gRPC services
    2 projects | /r/cpp | 21 Sep 2021
    Or check out the asio-grpc repository directly if you are looking to write asynchronous gRPC services with the features of Boost.Asio like C++20 coroutines, std::futures, stackless coroutines, callbacks and Boost.Coroutines.

libunifex

Posts with mentions or reviews of libunifex. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-23.
  • Comparing asio to unifex
    2 projects | /r/cpp | 23 Jun 2023
    I'm curious what led you to this conclusion. If you ran into scalability issues with its static_thread_pool, then that's a known issue. If it's something else, the authors (of which I'm one) would love to know.
  • How does one actually build a C++ project
    3 projects | /r/cpp_questions | 26 May 2023
    Instead of calling add_executable you will call add_library. Here is a (only moderately complicated) production example of a library that can be built standalone (along with tests and example executables), or as a subproject, where it builds only the library
  • How to write networking code now that will be easiest to adapt to the upcoming standard?
    2 projects | /r/cpp | 22 May 2023
    My original thought was to build my DDS implementation on top of libunifex in anticipation for standardization: https://github.com/facebookexperimental/libunifex
  • Executors/libunifex example project
    1 project | /r/Cplusplus | 10 Oct 2022
    I'm trying to understand how to work with the proposed executors in a project, but after watching Eric Niebler's cppcon talks (https://youtu.be/xLboNIf7BTg) and looking at the libunifex examples (https://github.com/facebookexperimental/libunifex/tree/main/examples) I still have a hard time wrapping my head around how to employ the sender/receiver pattern in a larger project.
  • Async/Await pattern in C++
    3 projects | /r/cpp_questions | 19 Jul 2022
    You have coroutines in C++20 but there is also the executives proposal that's making it's way into C++23 that is available as a library under the name unifex that only requires C++14
  • Using Asio for asynchronous gRPC clients and servers
    3 projects | /r/cpp | 6 Jun 2022
    Asio-grpc makes exactly that possible by providing an Asio execution_context compatible interface to the CompletionQueue. It supports all types of RPCs (including generic ones), completion tokens, cancellation, as well as libunifex sender/receiver (if you want to try out what might become std::execution). The latest release (v1.7.0) also introduced a GrpcStream class for writing Rust/Golang select-style code.
  • My thoughts and dreams about a standard user-space I/O scheduler
    4 projects | /r/cpp | 28 Apr 2022
    P2300: they are trying to standardize facebookexperimental/libunifex
  • "C++ makes it harder to shoot yourself, but when you do it blows your whole leg off"
    4 projects | /r/ProgrammerHumor | 18 Feb 2022
    All the network handling for Instagram and all other Meta apps on all platforms is handled by their own C++ library https://github.com/facebookexperimental/libunifex.
  • State of the art for CPOs (customization points) in C++?
    2 projects | /r/cpp | 3 Dec 2021
    This. I'd also like to mention libunifex. It's entirely based on tag_invoke and is a testament as to how much power it actually provides. On the other hand, it also proves how cumbersome it is to define CPOs with tag_invoke. But IMO it's a lot better than anything else anyone has ever created, and users usually don't need to define new CPOs, only library writers do, so there's that.
  • Why do we need networking, executors, linear algebra, etc in the Standard Library?
    2 projects | /r/cpp | 28 Nov 2021
    A work in progress implementation of the library: https://github.com/facebookexperimental/libunifex

What are some alternatives?

When comparing asio-grpc and libunifex you can also consider the following projects:

gRPC - The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)

cppcoro - A library of C++ coroutine abstractions for the coroutines TS

concurrencpp - Modern concurrency for C++. Tasks, executors, timers and C++20 coroutines to rule them all

RESTinio - Cross-platform, efficient, customizable, and robust asynchronous HTTP(S)/WebSocket server C++ library with the right balance between performance and ease of use

Taskflow - A General-purpose Parallel and Heterogeneous Task Programming System

lithium - Easy to use C++17 HTTP Server with no compromise on performances. https://matt-42.github.io/lithium

Restbed - Corvusoft's Restbed framework brings asynchronous RESTful functionality to C++14 applications.

corrade - C++11 multiplatform utility library

drachtio-freeswitch-modules - A collection of open-sourced freeswitch modules that I use in various drachtio applications

Boost.Beast - HTTP and WebSocket built on Boost.Asio in C++11