baseplate.go
go-zero
baseplate.go | go-zero | |
---|---|---|
7 | 102 | |
89 | 27,666 | |
- | 1.1% | |
6.6 | 9.6 | |
13 days ago | 5 days ago | |
Go | Go | |
BSD 3-clause "New" or "Revised" License | MIT License |
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.
baseplate.go
-
Just In Time Image Optimization at Reddit Scale
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
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
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)
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?
-
Evolving Reddit’s ML Model Deployment and Serving Architecture
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
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.
go-zero
- A simple way to use sync.WaitGroup.
-
A different and easy way to write web applications.
Check it out in https://github.com/zeromicro/go-zero
-
Best Web Sever Framework?
Maybe you can try https://github.com/zeromicro/go-zero, a different way to write your web applications. It generates the skeleton of your web apps.
- Best golang framework for microservice
- Does Go have a widely used framework, or it's used without anything?
-
What is the best microservices framework in Go?
Easy to use with start with https://github.com/zeromicro/go-zero, cannot say about long term.
-
Most Popular GoLang Frameworks
Website: https://go-zero.dev
-
go-zero v1.4.1 released - an ultimate microservice framework.
GitHub: https://github.com/zeromicro/go-zero
- Circuit Breaker Explained
-
Bulk Insert in SQLC
Maybe you can try this: https://github.com/zeromicro/go-zero/blob/master/core/stores/sqlx/bulkinserter.go
What are some alternatives?
Apache Thrift - Apache Thrift
kratos - Your ultimate Go microservices framework for the cloud-native era.
markup.rs - A blazing fast, type-safe template engine for Rust.
gin-boilerplate - The fastest way to deploy a restful api's with Gin Framework with a structured project that defaults to PostgreSQL database and JWT authentication middleware stored in Redis
Gin - Gin is a HTTP web framework written in Go (Golang). It features a Martini-like API with much better performance -- up to 40 times faster. If you need smashing performance, get yourself some Gin.
grpc-go - The Go language implementation of gRPC. HTTP/2 based RPC
go-micro - A Go microservices framework
GORM - The fantastic ORM library for Golang, aims to be developer friendly
go-web-framework-benchmark - :zap: Go web framework benchmark
go-micro - Go Micro is a framework for distributed systems development [Moved to: https://github.com/asim/go-micro]
zero-examples - go-zero examples
golang-generics-dao-example - Example using Generics with DAO