自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

字節(jié)跳動 Golang 微服務(wù) HTTP 框架 Hertz

開發(fā) 前端
Hertz[h??ts] 是一個 Golang 微服務(wù) HTTP 框架,在設(shè)計之初參考了其他開源框架 fasthttp、gin、echo 的優(yōu)勢, 并結(jié)合字節(jié)跳動內(nèi)部的需求,使其具有高易用性、高性能、高擴(kuò)展性等特點(diǎn),目前在字節(jié)跳動內(nèi)部已廣泛使用。

最近在研究字節(jié)、嗶哩嗶哩等開源技術(shù)的Golang框架,發(fā)現(xiàn)字節(jié)開源的Golang 微服務(wù) HTTP 框架Hertz,用起來相對舒服很多。

為什么選擇 Hertz

Hertz[h??ts] 是一個 Golang 微服務(wù) HTTP 框架,在設(shè)計之初參考了其他開源框架 fasthttp、gin、echo 的優(yōu)勢, 并結(jié)合字節(jié)跳動內(nèi)部的需求,使其具有高易用性、高性能、高擴(kuò)展性等特點(diǎn),目前在字節(jié)跳動內(nèi)部已廣泛使用。

如今越來越多的微服務(wù)選擇使用 Golang,如果對微服務(wù)性能有要求,又希望框架能夠充分滿足內(nèi)部的可定制化需求,Hertz 會是一個不錯的選擇。

架構(gòu)設(shè)計架構(gòu)設(shè)計

同時,也對Hertz做了高性能方面的對比

Hertz 默認(rèn)使用自研的高性能網(wǎng)絡(luò)庫 Netpoll,在一些特殊場景相較于 go net,Hertz 在 QPS、時延上均具有一定優(yōu)勢。關(guān)于性能數(shù)據(jù),可參考下圖 Echo 數(shù)據(jù)。

四個框架的對比

三個框架的對比:三個框架的對比:

框架特點(diǎn)

高易用性

在開發(fā)過程中,快速寫出來正確的代碼往往是更重要的。因此,在 Hertz 在迭代過程中,積極聽取用戶意見,持續(xù)打磨框架,希望為用戶提供一個更好的使用體驗,幫助用戶更快的寫出正確的代碼。

高性能

Hertz 默認(rèn)使用自研的高性能網(wǎng)絡(luò)庫 Netpoll,在一些特殊場景相較于 go net,Hertz 在 QPS、時延上均具有一定優(yōu)勢。關(guān)于性能數(shù)據(jù),可參考下圖 Echo 數(shù)據(jù)。

高擴(kuò)展性

Hertz 采用了分層設(shè)計,提供了較多的接口以及默認(rèn)的擴(kuò)展實(shí)現(xiàn),用戶也可以自行擴(kuò)展。同時得益于框架的分層設(shè)計,框架的擴(kuò)展性也會大很多。

多協(xié)議支持

Hertz 框架原生提供 HTTP1.1、ALPN 協(xié)議支持。除此之外,由于分層設(shè)計,Hertz 甚至支持自定義構(gòu)建協(xié)議解析邏輯,以滿足協(xié)議層擴(kuò)展的任意需求。

網(wǎng)絡(luò)層切換能力

Hertz 實(shí)現(xiàn)了 Netpoll 和 Golang 原生網(wǎng)絡(luò)庫 間按需切換能力,用戶可以針對不同的場景選擇合適的網(wǎng)絡(luò)庫,同時也支持以插件的方式為 Hertz 擴(kuò)展網(wǎng)絡(luò)庫實(shí)現(xiàn)。

Hertz

官網(wǎng)地址:https://www.cloudwego.io/zh/docs/hertz/

圖片圖片

官方介紹:

Hertz [h??ts] 是一個 Golang 微服務(wù) HTTP 框架,具有高易用性、高性能、高擴(kuò)展性等特點(diǎn)。

demo演示

  1. 準(zhǔn)備 Golang 開發(fā)環(huán)境
  2. 如果您之前未搭建 Golang 開發(fā)環(huán)境,可以參考 Golang 安裝。推薦使用最新版本的 Golang,或保證現(xiàn)有 Golang 版本 >= 1.16。小于 1.16 版本,可以自行嘗試使用但不保障兼容性和穩(wěn)定性。
  3. 確保打開 go mod 支持 (Golang >= 1.15 時,默認(rèn)開啟)。
  4. 完成安裝后,你可能需要設(shè)置一下國內(nèi)代理:go env -w GOPROXY=https://goproxy.cn。

目前,Hertz 支持 Linux、macOS、Windows 系統(tǒng)。

快速開發(fā)實(shí)踐

在完成環(huán)境準(zhǔn)備后,可以按照如下操作快速啟動 Hertz Server:

  1. 在當(dāng)前目錄下創(chuàng)建 hertz_demo 文件夾,進(jìn)入該目錄中。
  2. 創(chuàng)建 main.go 文件。
  3. 在 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()
}

圖片圖片

  1. 生成 go.mod 文件。
go mod init hertz_demo
  1. 整理 & 拉取依賴。
go mod tidy
  1. 運(yùn)行示例代碼。
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

接下來,我們可以對接口進(jìn)行測試:

curl http://127.0.0.1:8888/ping

如果不出意外,我們可以看到類似如下輸出:

{"message":"pong"}

圖片圖片

參考鏈接:https://www.cloudwego.io/zh/docs/hertz

責(zé)任編輯:武曉燕 來源: 程序員千羽
相關(guān)推薦

2024-11-13 11:02:03

微服務(wù)框架項目

2024-11-08 13:04:08

項目Hertz接口

2022-06-22 06:49:39

Hertz開源HTTP 框架

2022-10-14 14:44:04

字節(jié)跳動ByteTechHTTP 框架

2022-05-17 17:18:40

Kite字節(jié)跳動微服務(wù)框架

2021-09-09 09:05:30

開源字節(jié)跳動CloudWeGo

2022-11-24 09:01:26

HTTPHertz架構(gòu)

2024-08-20 09:59:22

2024-12-23 00:22:55

2022-08-25 18:48:29

字節(jié)跳動CSS開源

2018-12-17 16:44:49

Golang微服務(wù)

2018-12-17 16:39:20

Golang微服務(wù)

2018-12-17 16:48:05

Golang微服務(wù)

2023-04-19 16:51:54

分布式Primus開源

2024-09-25 15:57:56

2019-05-21 14:01:17

RPC框架Http

2023-10-18 11:56:17

開源AI

2021-01-29 10:33:34

存儲

2020-11-27 10:50:06

微服務(wù)架構(gòu)框架

2021-03-02 16:25:52

微服務(wù)架構(gòu)技術(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號