字節跳動 Golang 微服務 HTTP 框架 Hertz
最近在研究字節、嗶哩嗶哩等開源技術的Golang框架,發現字節開源的Golang 微服務 HTTP 框架Hertz,用起來相對舒服很多。
為什么選擇 Hertz
Hertz[h??ts] 是一個 Golang 微服務 HTTP 框架,在設計之初參考了其他開源框架 fasthttp、gin、echo 的優勢, 并結合字節跳動內部的需求,使其具有高易用性、高性能、高擴展性等特點,目前在字節跳動內部已廣泛使用。
如今越來越多的微服務選擇使用 Golang,如果對微服務性能有要求,又希望框架能夠充分滿足內部的可定制化需求,Hertz 會是一個不錯的選擇。
架構設計
同時,也對Hertz做了高性能方面的對比
Hertz 默認使用自研的高性能網絡庫 Netpoll,在一些特殊場景相較于 go net,Hertz 在 QPS、時延上均具有一定優勢。關于性能數據,可參考下圖 Echo 數據。
四個框架的對比
三個框架的對比:
框架特點
高易用性
在開發過程中,快速寫出來正確的代碼往往是更重要的。因此,在 Hertz 在迭代過程中,積極聽取用戶意見,持續打磨框架,希望為用戶提供一個更好的使用體驗,幫助用戶更快的寫出正確的代碼。
高性能
Hertz 默認使用自研的高性能網絡庫 Netpoll,在一些特殊場景相較于 go net,Hertz 在 QPS、時延上均具有一定優勢。關于性能數據,可參考下圖 Echo 數據。
高擴展性
Hertz 采用了分層設計,提供了較多的接口以及默認的擴展實現,用戶也可以自行擴展。同時得益于框架的分層設計,框架的擴展性也會大很多。
多協議支持
Hertz 框架原生提供 HTTP1.1、ALPN 協議支持。除此之外,由于分層設計,Hertz 甚至支持自定義構建協議解析邏輯,以滿足協議層擴展的任意需求。
網絡層切換能力
Hertz 實現了 Netpoll 和 Golang 原生網絡庫 間按需切換能力,用戶可以針對不同的場景選擇合適的網絡庫,同時也支持以插件的方式為 Hertz 擴展網絡庫實現。
Hertz
官網地址:https://www.cloudwego.io/zh/docs/hertz/
圖片
官方介紹:
Hertz [h??ts] 是一個 Golang 微服務 HTTP 框架,具有高易用性、高性能、高擴展性等特點。
demo演示
- 準備 Golang 開發環境
- 如果您之前未搭建 Golang 開發環境,可以參考 Golang 安裝。推薦使用最新版本的 Golang,或保證現有 Golang 版本 >= 1.16。小于 1.16 版本,可以自行嘗試使用但不保障兼容性和穩定性。
- 確保打開 go mod 支持 (Golang >= 1.15 時,默認開啟)。
- 完成安裝后,你可能需要設置一下國內代理:go env -w GOPROXY=https://goproxy.cn。
目前,Hertz 支持 Linux、macOS、Windows 系統。
快速開發實踐
在完成環境準備后,可以按照如下操作快速啟動 Hertz Server:
- 在當前目錄下創建 hertz_demo 文件夾,進入該目錄中。
- 創建 main.go 文件。
- 在 main.go 文件中添加以下代碼。
package main
import (
"context"
"github.com/cloudwego/hertz/pkg/app"
"github.com/cloudwego/hertz/pkg/app/server"
"github.com/cloudwego/hertz/pkg/common/utils"
"github.com/cloudwego/hertz/pkg/protocol/consts"
)
func main() {
h := server.Default()
h.GET("/ping", func(ctx context.Context, c *app.RequestContext) {
c.JSON(consts.StatusOK, utils.H{"message": "pong"})
})
h.Spin()
}
圖片
- 生成 go.mod 文件。
go mod init hertz_demo
- 整理 & 拉取依賴。
go mod tidy
- 運行示例代碼。
go run hertz_demo
如果成功啟動,你將看到以下信息:
PS D:\wx_vagrant\www\cloudwego\hertz\hertz_demo> go run hertz_demo
2024/11/07 10:01:48.832771 engine.go:669: [Debug] HERTZ: Method=GET absolutePath=/ping --> handlerName=main.main.func1 (num=2 handlers)
2024/11/07 10:01:48.849373 engine.go:397: [Info] HERTZ: Using network library=standard
2024/11/07 10:01:48.852301 transport.go:65: [Info] HERTZ: HTTP server listening on address=[::]:8888
接下來,我們可以對接口進行測試:
curl http://127.0.0.1:8888/ping
如果不出意外,我們可以看到類似如下輸出:
{"message":"pong"}
圖片
參考鏈接:https://www.cloudwego.io/zh/docs/hertz