2020-08-19 17:01:22 +08:00
# go-zero
2022-09-25 22:59:55 +08:00
< p align = "center" >
< img align = "center" width = "150px" src = "https://raw.githubusercontent.com/zeromicro/zero-doc/main/doc/images/go-zero.png" >
< / p >
2020-07-28 16:29:13 +08:00
2022-09-25 22:59:55 +08:00
go-zero is a web and rpc framework with lots of builtin engineering practices. It’ s born to ensure the stability of the busy services with resilience design and has been serving sites with tens of millions of users for years.
< div align = center >
2020-09-11 19:42:58 +08:00
2021-09-23 20:24:46 +08:00
[![Go ](https://github.com/zeromicro/go-zero/workflows/Go/badge.svg?branch=master )](https://github.com/zeromicro/go-zero/actions)
[![codecov ](https://codecov.io/gh/zeromicro/go-zero/branch/master/graph/badge.svg )](https://codecov.io/gh/zeromicro/go-zero)
[![Go Report Card ](https://goreportcard.com/badge/github.com/zeromicro/go-zero )](https://goreportcard.com/report/github.com/zeromicro/go-zero)
[![Release ](https://img.shields.io/github/v/release/zeromicro/go-zero.svg?style=flat-square )](https://github.com/zeromicro/go-zero)
2022-05-07 10:08:25 +08:00
[![Go Reference ](https://pkg.go.dev/badge/github.com/zeromicro/go-zero.svg )](https://pkg.go.dev/github.com/zeromicro/go-zero)
[![Awesome Go ](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg )](https://github.com/avelino/awesome-go)
2020-08-15 15:16:57 +08:00
[![License: MIT ](https://img.shields.io/badge/License-MIT-yellow.svg )](https://opensource.org/licenses/MIT)
2022-02-25 23:01:15 +08:00
[![Discord ](https://img.shields.io/discord/794530774463414292?label=chat&logo=discord )](https://discord.gg/4JQvC5A4Fe)
2022-05-07 10:11:21 +08:00
2022-09-25 22:59:55 +08:00
< / div >
## 🤷 What is go-zero?
English | [简体中文 ](readme-cn.md )
2020-08-09 23:22:31 +08:00
2022-09-25 22:59:55 +08:00
< a href = "https://www.producthunt.com/posts/go-zero?utm_source=badge-featured&utm_medium=badge&utm_souce=badge-go-zero" target = "_blank" > < img src = "https://api.producthunt.com/widgets/embed-image/v1/featured.svg?post_id=334030&theme=light" alt = "go-zero - A web & rpc framework written in Go. | Product Hunt" style = "width: 250px; height: 54px;" width = "250" height = "54" / > < / a >
2022-02-27 23:25:22 +08:00
2020-08-21 16:52:17 +08:00
2022-01-22 12:20:11 +08:00
go-zero (listed in CNCF Landscape: [https://landscape.cncf.io/?selected=go-zero ](https://landscape.cncf.io/?selected=go-zero )) is a web and rpc framework with lots of builtin engineering practices. It’ s born to ensure the stability of the busy services with resilience design and has been serving sites with tens of millions of users for years.
2020-08-21 16:52:17 +08:00
2021-02-02 16:58:45 +08:00
go-zero contains simple API description syntax and code generation tool called `goctl` . You can generate Go, iOS, Android, Kotlin, Dart, TypeScript, JavaScript from .api files with `goctl` .
2020-08-21 16:52:17 +08:00
2022-09-25 22:59:55 +08:00
#### Advantages of go-zero:
2020-08-21 22:51:04 +08:00
2021-02-02 16:58:45 +08:00
* improve the stability of the services with tens of millions of daily active users
* builtin chained timeout control, concurrency control, rate limit, adaptive circuit breaker, adaptive load shedding, even no configuration needed
* builtin middlewares also can be integrated into your frameworks
2022-01-22 12:20:11 +08:00
* simple API syntax, one command to generate a couple of different languages
2021-02-02 16:58:45 +08:00
* auto validate the request parameters from clients
* plenty of builtin microservice management and concurrent toolkits
2020-08-21 22:51:04 +08:00
2021-09-24 11:31:00 +08:00
< img src = "https://raw.githubusercontent.com/zeromicro/zero-doc/main/doc/images/architecture-en.png" alt = "Architecture" width = "1500" / >
2020-08-21 20:09:53 +08:00
2022-09-25 22:59:55 +08:00
## Backgrounds of go-zero
2020-07-28 16:29:13 +08:00
2022-01-22 12:20:11 +08:00
At the beginning of 2018, we decided to re-design our system, from monolithic architecture with Java+MongoDB to microservice architecture. After research and comparison, we chose to:
2020-07-28 16:29:13 +08:00
2021-02-02 16:58:45 +08:00
* Golang based
* great performance
* simple syntax
* proven engineering efficiency
* extreme deployment experience
* less server resource consumption
* Self-designed microservice architecture
2022-01-22 12:20:11 +08:00
* I have rich experience in designing microservice architectures
* easy to locate the problems
2021-02-02 16:58:45 +08:00
* easy to extend the features
2020-07-28 16:29:13 +08:00
2022-09-25 22:59:55 +08:00
## Design considerations on go-zero
2020-07-28 16:29:13 +08:00
2022-01-22 12:20:11 +08:00
By designing the microservice architecture, we expected to ensure stability, as well as productivity. And from just the beginning, we have the following design principles:
2020-07-28 16:29:13 +08:00
2021-02-02 16:58:45 +08:00
* keep it simple
* high availability
* stable on high concurrency
* easy to extend
* resilience design, failure-oriented programming
* try best to be friendly to the business logic development, encapsulate the complexity
* one thing, one way
2020-07-28 16:29:13 +08:00
2022-01-22 12:20:11 +08:00
After almost half a year, we finished the transfer from a monolithic system to microservice system and deployed on August 2018. The new system guaranteed business growth and system stability.
2020-07-28 16:29:13 +08:00
2022-09-25 22:59:55 +08:00
## The implementation and features of go-zero
2020-07-28 16:29:13 +08:00
2021-02-02 16:58:45 +08:00
go-zero is a web and rpc framework that integrates lots of engineering practices. The features are mainly listed below:
2020-07-28 16:29:13 +08:00
2021-02-02 16:58:45 +08:00
* powerful tool included, less code to write
* simple interfaces
* fully compatible with net/http
* middlewares are supported, easy to extend
* high performance
* failure-oriented programming, resilience design
* builtin service discovery, load balancing
2022-01-22 12:20:11 +08:00
* builtin concurrency control, adaptive circuit breaker, adaptive load shedding, auto-trigger, auto recover
2021-02-02 16:58:45 +08:00
* auto validation of API request parameters
* chained timeout control
* auto management of data caching
2022-01-22 12:20:11 +08:00
* call tracing, metrics, and monitoring
2021-02-02 16:58:45 +08:00
* high concurrency protected
2020-07-28 16:29:13 +08:00
2022-01-22 12:20:11 +08:00
As below, go-zero protects the system with a couple of layers and mechanisms:
2020-07-28 16:29:13 +08:00
2021-09-24 11:31:00 +08:00
![Resilience ](https://raw.githubusercontent.com/zeromicro/zero-doc/main/doc/images/resilience-en.png )
2020-07-28 16:29:13 +08:00
2022-09-25 22:59:55 +08:00
## The simplified architecture that we use with go-zero
2020-11-03 16:35:34 +08:00
2022-06-03 23:02:54 +08:00
< img width = "1067" alt = "image" src = "https://user-images.githubusercontent.com/1918356/171880372-5010d846-e8b1-4942-8fe2-e2bbb584f762.png" >
2020-08-08 13:40:11 +08:00
2022-09-25 22:59:55 +08:00
## Installation
2021-02-02 16:58:45 +08:00
Run the following command under your project:
2020-08-08 13:40:11 +08:00
2020-08-20 10:44:14 +08:00
```shell
2022-02-01 13:03:30 +08:00
go get -u github.com/zeromicro/go-zero
2020-08-20 10:44:14 +08:00
```
2022-09-25 22:59:55 +08:00
## Upgrade
To upgrade from versions eariler than v1.3.0, run the following commands.
```shell
go install github.com/zeromicro/go-zero/tools/goctl@latest
```
```shell
2023-04-30 11:21:28 +08:00
goctl migrate —verbose —version v1.5.2
2022-09-25 22:59:55 +08:00
```
2020-08-08 13:40:11 +08:00
2022-09-25 22:59:55 +08:00
## Quick Start
2020-09-04 15:40:12 +08:00
2022-09-25 22:59:55 +08:00
1. full examples can be checked out from below:
2020-08-31 22:37:43 +08:00
2021-09-24 11:31:00 +08:00
[Rapid development of microservice systems ](https://github.com/zeromicro/zero-doc/blob/main/doc/shorturl-en.md )
2020-08-08 13:40:11 +08:00
2021-09-24 11:31:00 +08:00
[Rapid development of microservice systems - multiple RPCs ](https://github.com/zeromicro/zero-doc/blob/main/docs/zero/bookstore-en.md )
2020-08-14 15:31:10 +08:00
2022-09-25 22:59:55 +08:00
2. install goctl
2020-08-30 23:34:57 +08:00
2022-01-22 12:20:11 +08:00
`goctl` can be read as `go control` . `goctl` means not to be controlled by code, instead, we control it. The inside `go` is not `golang` . At the very beginning, I was expecting it to help us improve productivity, and make our lives easier.
2020-08-30 23:34:57 +08:00
2021-02-02 16:58:45 +08:00
```shell
2023-03-10 22:18:48 +08:00
# for Go
2022-02-01 13:03:30 +08:00
go install github.com/zeromicro/go-zero/tools/goctl@latest
2023-03-10 22:18:48 +08:00
2022-05-28 14:39:25 +08:00
# For Mac
brew install goctl
2023-03-10 22:18:48 +08:00
2022-04-05 11:51:09 +08:00
# docker for amd64 architecture
docker pull kevinwan/goctl
# run goctl like
docker run --rm -it -v `pwd` :/app kevinwan/goctl goctl --help
2023-03-10 22:18:48 +08:00
2022-04-05 11:51:09 +08:00
# docker for arm64 (M1) architecture
docker pull kevinwan/goctl:latest-arm64
# run goctl like
docker run --rm -it -v `pwd` :/app kevinwan/goctl:latest-arm64 goctl --help
2021-02-02 16:58:45 +08:00
```
2023-03-10 22:18:48 +08:00
2021-02-02 16:58:45 +08:00
make sure goctl is executable.
2023-03-10 22:18:48 +08:00
2022-09-25 22:59:55 +08:00
3. create the API file, like greet.api, you can install the plugin of goctl in vs code, api syntax is supported.
2020-09-11 19:42:58 +08:00
2021-02-02 16:58:45 +08:00
```go
2021-08-10 18:02:11 +08:00
type (
Request {
2023-01-03 23:14:39 +08:00
Name string `path:"name,options=[you,me]"` // parameters are auto validated
2021-08-10 18:02:11 +08:00
}
2023-02-23 14:36:58 +08:00
2021-08-10 18:02:11 +08:00
Response {
Message string `json:"message"`
}
)
2023-02-23 14:36:58 +08:00
2021-02-02 16:58:45 +08:00
service greet-api {
@handler GreetHandler
2021-08-11 10:51:28 +08:00
get /greet/from/:name(Request) returns (Response)
2021-02-02 16:58:45 +08:00
}
```
2023-02-23 14:36:58 +08:00
2022-01-22 12:20:11 +08:00
the .api files also can be generated by goctl, like below:
2020-08-08 13:40:11 +08:00
2021-02-02 16:58:45 +08:00
```shell
goctl api -o greet.api
```
2023-02-23 14:36:58 +08:00
2022-09-25 22:59:55 +08:00
4. generate the go server-side code
2020-10-22 22:24:35 +08:00
2021-02-02 16:58:45 +08:00
```shell
goctl api go -api greet.api -dir greet
```
2020-08-09 21:32:23 +08:00
2021-02-02 16:58:45 +08:00
the generated files look like:
2020-08-19 12:43:14 +08:00
2021-02-02 16:58:45 +08:00
```Plain Text
├── greet
│ ├── etc
│ │ └── greet-api.yaml // configuration file
│ ├── greet.go // main file
│ └── internal
│ ├── config
│ │ └── config.go // configuration definition
│ ├── handler
│ │ ├── greethandler.go // get/put/post/delete routes are defined here
│ │ └── routes.go // routes list
│ ├── logic
│ │ └── greetlogic.go // request logic can be written here
│ ├── svc
│ │ └── servicecontext.go // service context, mysql/redis can be passed in here
│ └── types
│ └── types.go // request/response defined here
└── greet.api // api description file
```
2020-08-19 12:43:14 +08:00
2021-02-02 16:58:45 +08:00
the generated code can be run directly:
2020-09-08 09:24:12 +08:00
2021-02-02 16:58:45 +08:00
```shell
cd greet
go mod init
go mod tidy
go run greet.go -f etc/greet-api.yaml
```
2020-09-28 16:58:29 +08:00
2022-01-22 12:20:11 +08:00
by default, it’ s listening on port 8888, while it can be changed in the configuration file.
2020-09-28 16:58:29 +08:00
2021-02-02 16:58:45 +08:00
you can check it by curl:
2020-09-28 16:58:29 +08:00
2021-02-02 16:58:45 +08:00
```shell
2021-02-03 10:18:28 +08:00
curl -i http://localhost:8888/greet/from/you
2021-02-02 16:58:45 +08:00
```
2021-01-09 00:17:23 +08:00
2022-01-22 12:20:11 +08:00
the response looks like below:
2020-08-14 15:31:10 +08:00
2021-02-02 16:58:45 +08:00
```http
HTTP/1.1 200 OK
Date: Sun, 30 Aug 2020 15:32:35 GMT
Content-Length: 0
```
2020-12-15 23:47:41 +08:00
2022-09-25 22:59:55 +08:00
5. Write the business logic code
2020-12-15 23:47:41 +08:00
2022-01-22 12:20:11 +08:00
* the dependencies can be passed into the logic within servicecontext.go, like mysql, reds, etc.
* add the logic code in a logic package according to .api file
2020-12-15 23:47:41 +08:00
2022-09-25 22:59:55 +08:00
6. Generate code like Java, TypeScript, Dart, JavaScript, etc. just from the api file
2020-08-09 21:32:23 +08:00
2021-02-02 16:58:45 +08:00
```shell
goctl api java -api greet.api -dir greet
goctl api dart -api greet.api -dir greet
...
```
2020-10-11 19:42:40 +08:00
2022-09-25 22:59:55 +08:00
## Benchmark
2020-10-11 19:42:40 +08:00
2021-09-24 11:31:00 +08:00
![benchmark ](https://raw.githubusercontent.com/zeromicro/zero-doc/main/doc/images/benchmark.png )
2020-10-11 19:42:40 +08:00
2021-02-02 16:58:45 +08:00
[Checkout the test code ](https://github.com/smallnest/go-web-framework-benchmark )
2020-10-29 15:32:08 +08:00
2022-09-25 22:59:55 +08:00
## Documents
2020-10-29 15:32:08 +08:00
2022-06-25 11:18:47 +08:00
* [Documents ](https://go-zero.dev/ )
2021-09-24 11:31:00 +08:00
* [Rapid development of microservice systems ](https://github.com/zeromicro/zero-doc/blob/main/doc/shorturl-en.md )
* [Rapid development of microservice systems - multiple RPCs ](https://github.com/zeromicro/zero-doc/blob/main/docs/zero/bookstore-en.md )
2021-02-08 22:23:36 +08:00
* [Examples ](https://github.com/zeromicro/zero-examples )
2020-10-31 20:11:12 +08:00
2022-09-25 22:59:55 +08:00
## Chat group
2020-10-29 15:32:08 +08:00
2022-02-25 23:02:09 +08:00
Join the chat via https://discord.gg/4JQvC5A4Fe
2021-05-08 21:55:14 +08:00
2022-09-25 22:59:55 +08:00
## Cloud Native Landscape
2021-10-11 15:31:29 +08:00
< p float = "left" >
< img src = "https://landscape.cncf.io/images/left-logo.svg" width = "150" / >
< img src = "https://landscape.cncf.io/images/right-logo.svg" width = "200" / >
< / p >
go-zero enlisted in the [CNCF Cloud Native Landscape ](https://landscape.cncf.io/?selected=go-zero ).
2021-05-08 21:55:14 +08:00
## Give a Star! ⭐
2021-08-10 18:02:11 +08:00
If you like or are using this project to learn or start your solution, please give it a star. Thanks!
2022-06-19 20:50:55 +08:00
## Buy me a coffee
2022-07-01 22:17:05 +08:00
< a href = "https://www.buymeacoffee.com/kevwan" target = "_blank" > < img src = "https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt = "Buy Me A Coffee" style = "height: 60px !important;width: 217px !important;" > < / a >