Apache Thrift VS baseplate.go

Compare Apache Thrift vs baseplate.go and see what are their differences.

Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
Apache Thrift baseplate.go
10 7
10,135 90
0.5% -
8.9 6.6
7 days ago about 17 hours ago
C++ Go
Apache License 2.0 BSD 3-clause "New" or "Revised" License
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.

Apache Thrift

Posts with mentions or reviews of Apache Thrift. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-08-20.

baseplate.go

Posts with mentions or reviews of baseplate.go. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-28.
  • Just In Time Image Optimization at Reddit Scale
    3 projects | /r/RedditEng | 28 Jun 2023
    We chose to use govips which is a cgo wrapper around the libvips image manipulation library. The majority of new development for services in our backend is written using baseplate.go. But Go is not an ideal choice for media processing as it cannot keep up with the performance of native code. The most widely used image-processing libraries like libmagick are primarily written in C or C++. Speed was a major factor in selecting libvips in order to keep latency low on CDN cache misses for images. In our tests, libvips was 3–4 times faster than libmagick on basic image processing operations. Content-aware smart cropping was implemented by porting smartcrop.js to Go. This is the only operation implemented in pure Go.
  • Python use by SWEs
    2 projects | /r/cscareerquestions | 7 May 2023
    Even Reddit has python backends https://github.com/reddit/baseplate.py based on Pyramid. They also have a go one. https://github.com/reddit/baseplate.go
  • Reddit System Design/Architecture
    5 projects | /r/redditdev | 19 Mar 2023
    there's a multitude of services in reddit's architecture. as far as i can tell, they mostly using reddit's baseplate framework (which has implementations in both python and go).
  • 3 of the top 5 fastest web frameworks are written in Rust! (#1, #3 and #5)
    4 projects | /r/rust | 15 Aug 2022
    FWIW, I believe Reddit has rewritten some Python into Go because of scaling issues. I don't know of any public write ups to confirm it, but at the least there's a public repo that contains their base template.
  • How do you maintain quality of code in a Go project?
    4 projects | /r/golang | 20 Mar 2022
  • Evolving Reddit’s ML Model Deployment and Serving Architecture
    3 projects | /r/RedditEng | 4 Oct 2021
    Gazette Inference Service is a baseplate.go (Reddit’s golang web services framework) thrift service whose single responsibility is serving ML inference requests to it’s clients. It is deployed with Reddit’s modern kubernetes infrastructure.
  • Deadline Budget Propagation for Baseplate.py
    3 projects | /r/RedditEng | 27 Sep 2021
    Baseplate is implemented in Python and Go, and although they share the same main functionality, smaller features differ between the two. One such feature that was previously on the Go implementation but not Python was deadline budget propagation, which passes on the remaining timeout available from the initial client request all the way through the server and any other requests that may follow. The lack of this feature in Baseplate.py meant that many resources were being wasted by servers doing unnecessary work, despite clients no longer awaiting their response due to timeout.

What are some alternatives?

When comparing Apache Thrift and baseplate.go you can also consider the following projects:

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

markup.rs - A blazing fast, type-safe template engine for Rust.

ZeroMQ - ZeroMQ core engine in C++, implements ZMTP/3.1

Cap'n Proto - Cap'n Proto serialization/RPC system - core tools and C++ library

Protobuf - Protocol Buffers - Google's data interchange format

Apache Avro - Apache Avro is a data serialization system.

Apache Parquet - Apache Parquet

nanomsg - nanomsg library

Big Queue - A big, fast and persistent queue based on memory mapped file.

rpclib - rpclib is a modern C++ msgpack-RPC server and client library

Apache Orc - Apache ORC - the smallest, fastest columnar storage for Hadoop workloads

SBE - Simple Binary Encoding (SBE) - High Performance Message Codec