go_serialization_benchmarks
tempo
go_serialization_benchmarks | tempo | |
---|---|---|
8 | 13 | |
1,527 | 385 | |
- | 0.8% | |
4.4 | 7.0 | |
12 days ago | about 2 months ago | |
Go | TypeScript | |
- | 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.
go_serialization_benchmarks
-
Rob Pike: Gobs of data (2011)
Someone made a benchmark of serialization libraries in go [1], and I was surprised to see gobs is one of the slowest ones, specially for decoding. I suspect part of the reason is that the API doesn't not allow reusing decoders [2]. From my explorations it seems like both JSON [3], message-pack [4] and CBOR [5] are better alternatives.
By the way, in Go there are a like a million JSON encoders because a lot of things in the std library are not really coded for maximum performance but more for easy of usage, it seems. Perhaps this is the right balance for certain things (ex: the http library, see [6]).
There are also a bunch of libraries that allow you to modify a JSON file "in place", without having to fully deserialize into structs (ex: GJSON/SJSON [7] [8]). This sounds very convenient and more efficient that fully de/serializing if we just need to change the data a little.
--
1: https://github.com/alecthomas/go_serialization_benchmarks
2: https://github.com/golang/go/issues/29766#issuecomment-45492...
--
3: https://github.com/goccy/go-json
4: https://github.com/vmihailenco/msgpack
5: https://github.com/fxamacker/cbor
--
6: https://github.com/valyala/fasthttp#faq
--
7: https://github.com/tidwall/gjson
8: https://github.com/tidwall/sjson
-
Introducing Tempo: low latency, cross-platform, end-to-end typesafe APIs
The bebop definition specifies fixed-width types inside a struct. The format of structs cannot be changed, but there are efficiency gains by omitting all of the indices and header data. It's useless as the root message, but it's small and fast for a benchmark.
-
mus-go - the fastest Golang serializer today
Hey everyone! Let me introduce you to mus-go - the fastest Golang serializer today. If you look at benchmarks (https://github.com/alecthomas/go_serialization_benchmarks), you can see that it could be almost twice as fast as its closest "competitor":
-
What is the fastest way to encode the arbitrary struct into bytes?
This might be of interest: https://github.com/alecthomas/go_serialization_benchmarks
- 80x improvements in caching by moving from JSON to gob
-
gRPC Is Easy to Misconfigure
The protobuf vs msgpack benchmarks are not too bad. Msgpack performs very decently.
https://github.com/alecthomas/go_serialization_benchmarks
-
Bebop encoding in Go
Maybe submit a PR against https://github.com/alecthomas/go_serialization_benchmarks? That covers a ton of serialization formats already, so adding your library would be cool and avoid wheel reinvention.
tempo
-
Popular Libraries For Building Type-safe Web Application APIs
There are still a few more libraries in development. An example is Tempo by betwixt-labs.
-
Bebop introduces JSON-Over-Bebop for fast runtime type validation of raw JSON in Typescript; faster than Zod and other alternatives
JSON-Over-Bebop was introduced to provide the API framework built on top of Bebop, Tempo, with the ability to send and receive JSON over the wire to help migrate brownfield projects or those who want to get started building using a more familiar interchange format - but without breaking the type safety guarantees Bebop and Tempo make at compile and runtime.
-
Construction Injection without DI framework
I’m a C# developer too - you should check out Tempo (disclaimer i built it) https://github.com/betwixt-labs/tempo
- Show HN: Tempo – gRPC alternative, quicker and browser/serverless-friendly
- Tempo: real-time, end-to-end typesafe APIs on Cloudflare Workers
- Empo: Low latency, cross-platform, end-to-end typesafe APIs
-
Introducing Tempo: low latency, cross-platform, end-to-end typesafe APIs
Thank you! If you (or anyone) wants to contribute, we have an RFC for the authentication and authorization mechanism in Tempo we'd love feedback on. https://github.com/betwixt-labs/tempo/discussions/1
What are some alternatives?
bebop - bebop wire format in Go
SerializationBenchmarks - Benchmarking .NET Serialization Performance
encoding - Go package containing implementations of efficient encoding, decoding, and validation APIs.
tempo - Grafana Tempo is a high volume, minimal dependency distributed tracing backend.
bebop - 🎷No ceremony, just code. Blazing fast, typesafe binary serialization.
template-worker-tempo - A template that demonstrates using the Tempo in your Cloudflare Workers.
msgpack - MessagePack is an extremely efficient object serialization library. It's like JSON, but very fast and small.
grpc-web - gRPC for Web Clients
di - A compile-time powered Dependency-Injection container for Typescript that holds services and can produce instances of them as required.
msgp - A Go code generator for MessagePack / msgpack.org[Go]
go-codec-bench - Benchmark of go binary and text encodings