csproto
twirp
csproto | twirp | |
---|---|---|
3 | 30 | |
117 | 6,836 | |
0.9% | 0.6% | |
6.6 | 3.5 | |
4 days ago | about 1 month ago | |
Go | Go | |
MIT License | Apache License 2.0 |
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.
csproto
- Csproto – CrowdStrike's Protocol Buffers Library
-
Crowdstrike releases replacement for gogo/protobuf
Crowdstrike internally has been struggling with how to deal with gogo/proto essentially being EOL while also being able to gracefully transition off of it. They've worked on 2 things here:
1. A wrapper to allow easy moving off of Gogo back to Google protobuf thats able to marshal and unmarshal protobufs from any of gogo, google proto v1, or google proto v2
2. A custom encoder and decoder that is optimized for runtime performance (around 20% faster for proto2 and around 40% faster for proto3)
Source: https://github.com/CrowdStrike/csproto
twirp
-
I Reviewed 1,000s of Opinions on gRPC
The next time I want to build an API, I will probably make use of https://github.com/twitchtv/twirp. I like working with Protobuf and having strongly-typed and well-defined messages, but gRPC is way, way too much. It's obviously a Google product, built for what Google needs.
Use Protobuf for messages, but just use HTTP for transport.
- How do I provide bot RPC and REST endpoints?
- Reasons to use gRPC/Protobuf?
-
A detailed comparison of REST and gRPC
- Twirp (Twitch light version of gRPC, with optional JSON encoding, HTTP1 support and without streaming) - https://github.com/twitchtv/twirp
-
goRPC or gRPC?
There is another: twirp
-
TypeScript type safety with GO
And addition to what was mentioned there are also webrpc and twirp.
-
Any good open source python projects that have used GRPC?
If you find one, you maybe also interested in twirp.
-
GraphQL making its way into a Twitter discussion about latency is not what I expected
Twitch has a great framework for it https://twitchtv.github.io/twirp/docs/intro.html
-
swaggo/swag alternative, but should generate OpenAPI 3.0 spec file
We have better experience with https://goa.design/ than with https://github.com/twitchtv/twirp
-
Connect-Web: It's time for Protobuf/gRPC to be your first choice in the browser
Take a look at Twirp (https://github.com/twitchtv/twirp) open sourced by TwitchTv. It's a lot lighter weight than gRPC. It does use Protobufs but addresses some of the concerns you mentioned, such as being able to test with JSON payloads, works over HTTP 1.1 and HTTP/2, good client libraries, and doesn't require a proxy.
They address your concerns in more detail in the Twirp release announcement (2018) - https://blog.twitch.tv/en/2018/01/16/twirp-a-sweet-new-rpc-f...
What are some alternatives?
vtprotobuf - A Protocol Buffers compiler that generates optimized marshaling & unmarshaling Go code for ProtoBuf APIv2
drpc - drpc is a lightweight, drop-in replacement for gRPC
kratos - Your ultimate Go microservices framework for the cloud-native era.
grpc-web - gRPC Web implementation for Golang and TypeScript
gogoprotobuf - [Deprecated] Protocol Buffers for Go with Gadgets
prisma-client-go - Prisma Client Go is an auto-generated and fully type-safe database client
goprotobuf - Go support for Google's protocol buffers
swagger-petstore - swagger-codegen contains a template-driven engine to generate documentation, API clients and server stubs in different languages by parsing your OpenAPI / Swagger definition.
protoactor-go - Proto Actor - Ultra fast distributed actors for Go, C# and Java/Kotlin
protobuf-ts - Protobuf and RPC for TypeScript
Protobuf - Protocol Buffers - Google's data interchange format
gRPC - The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)