字节跳动自研HTTP开源框架Hertz简介附使用示例

news/2025/1/30 14:40:45/
http://www.w3.org/2000/svg" style="display: none;">
字节跳动自研 HTTP 框架 Hertz

Hertz 是字节跳动自研的高性能 HTTP 框架,专为高并发、低延迟的场景设计。它基于 Go 语言开发,结合了字节跳动在微服务架构中的实践经验,旨在提供更高效的 HTTP 服务开发体验。
https://i-blog.csdnimg.cn/direct/eea8040792594e4d9ef029cb8e7d9794.png" alt="在这里插入图片描述" />


1. 背景介绍

随着字节跳动业务的快速发展,传统的 HTTP 框架(如 Gin、Echo 等)在高并发场景下逐渐暴露出性能瓶颈。为了满足业务需求,字节跳动团队决定自研一款高性能的 HTTP 框架,Hertz 应运而生。

Hertz 的设计目标是:

  • 高性能:在高并发场景下提供更低的延迟和更高的吞吐量。
  • 易用性:提供简洁的 API 和丰富的功能,降低开发成本。
  • 可扩展性:支持插件化扩展,方便集成各种中间件和工具。

2. 核心特性

Hertz 具有以下核心特性:

高性能
  • 基于 net/http 优化:Hertz 在 Go 标准库 net/http 的基础上进行了深度优化,减少了不必要的内存分配和系统调用。
  • 零拷贝技术:通过零拷贝技术减少数据复制,提高数据传输效率。
  • 高效路由:使用 Radix Tree 实现高效的路由匹配,支持动态路由和参数解析。
易用性
  • 简洁的 API:Hertz 提供了类似 Gin 的 API 设计,开发者可以快速上手。
  • 丰富的中间件:内置了日志、限流、熔断等常用中间件,支持自定义中间件。
  • 自动生成代码:通过代码生成工具自动生成路由、模型和接口代码,减少手动编码工作量。
可扩展性
  • 插件化架构:Hertz 支持插件化扩展,开发者可以轻松集成第三方工具和服务。
  • 多协议支持:除了 HTTP/1.1,还支持 HTTP/2 和 gRPC,满足多种业务场景需求。

3. 架构设计

Hertz 的架构设计分为以下几个核心模块:

路由模块
  • Radix Tree:使用 Radix Tree 实现高效的路由匹配,支持动态路由和参数解析。
  • 路由分组:支持路由分组,方便管理和维护大型项目。
中间件模块
  • 链式调用:中间件采用链式调用模式,支持按需加载和组合。
  • 内置中间件:提供了日志、限流、熔断、鉴权等常用中间件。
上下文模块
  • Context 封装:对 http.Requesthttp.ResponseWriter 进行了封装,提供了更简洁的 API。
  • 数据绑定:支持 JSON、XML、表单等数据格式的自动绑定和验证。
插件模块
  • 插件化设计:支持通过插件扩展框架功能,如集成 Prometheus 监控、Jaeger 分布式追踪等。

4. 性能优化

Hertz 在性能优化方面做了大量工作,主要包括:

减少内存分配
  • 对象池技术:通过对象池复用内存对象,减少 GC 压力。
  • 零拷贝技术:减少数据复制,提高数据传输效率。
高效路由匹配
  • Radix Tree:使用 Radix Tree 实现高效的路由匹配,减少匹配时间。
并发控制
  • 协程池:通过协程池限制并发 Goroutine 数量,避免资源耗尽。
  • 限流和熔断:内置限流和熔断机制,防止服务过载。

5. 使用场景

Hertz 适用于以下场景:

高并发服务
  • 推荐系统:为推荐系统提供低延迟的 HTTP 接口。
  • 广告系统:支持高并发的广告请求处理。
微服务架构
  • API 网关:作为微服务架构中的 API 网关,提供统一的入口和路由。
  • 内部服务:用于构建高性能的内部微服务。
实时数据处理
  • 消息推送:支持实时消息推送服务。
  • 数据采集:用于高并发的数据采集和处理。

http://www.w3.org/2000/svg" height="254" viewbox="0 0 1242.925048828125 254" class="mermaid-svg">
Hertz 架构
路由模块
中间件模块
上下文模块
插件模块
Radix Tree 路由匹配
路由分组
链式调用中间件
内置中间件
Context 封装
数据绑定
插件化扩展
多协议支持
代码示例

基本使用

package mainimport ("github.com/cloudwego/hertz/pkg/app""github.com/cloudwego/hertz/pkg/app/server"
)func main() {h := server.Default()h.GET("/hello", func(c *app.Context) {c.String(200, "Hello, Hertz!")})h.Spin()
}

使用中间件

package mainimport ("github.com/cloudwego/hertz/pkg/app""github.com/cloudwego/hertz/pkg/app/server""github.com/cloudwego/hertz/pkg/common/middleware"
)func main() {h := server.Default()// 使用日志中间件h.Use(middleware.Logger())h.GET("/hello", func(c *app.Context) {c.String(200, "Hello, Hertz with Middleware!")})h.Spin()
}

数据绑定

package mainimport ("github.com/cloudwego/hertz/pkg/app""github.com/cloudwego/hertz/pkg/app/server"
)type User struct {Name string `json:"name"`Age  int    `json:"age"`
}func main() {h := server.Default()h.POST("/user", func(c *app.Context) {var user Userif err := c.Bind(&user); err != nil {c.String(400, "Bad Request")return}c.JSON(200, user)})h.Spin()
}

http://www.ppmy.cn/news/1567911.html

相关文章

OSCP:发送钓鱼电子邮件执行客户端攻击

概述 在渗透测试领域,钓鱼攻击是一种有效的客户端攻击手段,尤其在目标用户缺乏安全意识或系统存在未修复漏洞时,成功率较高。针对Windows平台,滥用Windows库文件(.Library-ms)是一种技术性较强但易于实施的…

Linux学习笔记——用户管理

一、用户管理命令 useradd #用户增加命令 usermod #用户修改命令 passwd #密码修改命令 userdel #用户删除命令 su #用户提权命令 1、useradd命令(加用户): 创建并设置用户信息,使用us…

剑指 Offer II 007. 数组中和为 0 的三个数

comments: true edit_url: https://github.com/doocs/leetcode/edit/main/lcof2/%E5%89%91%E6%8C%87%20Offer%20II%20007.%20%E6%95%B0%E7%BB%84%E4%B8%AD%E5%92%8C%E4%B8%BA%200%20%E7%9A%84%E4%B8%89%E4%B8%AA%E6%95%B0/README.md 剑指 Offer II 007. 数组中和为 0 的三个数 …

Ubuntu二进制部署K8S 1.29.2

本机说明 本版本非高可用,单Master,以及一个Node 新装的 ubuntu 22.04k8s 1.29.3使用该文档请使用批量替换 192.168.44.141这个IP,其余照着复制粘贴就可以成功需要手动 设置一个 固定DNS,我这里设置的是 8.8.8.8不然coredns无法…

DeepSeek部署教程(基于Ollama)

虽说在过年,但不能忘了学习。这几天科技圈最火的莫过于deepseek,我抽空也学习一下deepseek的部署过程,主要还是因为官方服务已经彻底瘫了[手动狗头]。 1、下载Ollama并安装 https://github.com/ollama/ollama/releases/latest/download/Oll…

使用 ECS服务器 和 vsCode 搭建远程开发站

SSH 连接测试 学习过 Linux 的应该对 SSH 很了解,使用在此不介绍 Linux 上的使用 在 Window 中打开 PowerShell 程序【此处不知道 PowerShell 可以百度一下,不做过多介绍】 方法一:按住 Shift ,鼠标右键桌面 方法二&#xff1…

【深度学习】常见模型-Transformer模型

Transformer 是一种深度学习模型,首次由 Vaswani 等人在 2017 年提出(论文《Attention is All You Need》),在自然语言处理(NLP)领域取得了革命性成果。它的核心思想是通过 自注意力机制(Self-A…

芸众商城小程序会员页面部分图标不显示问题解决办法

我遇到的问题 如下图所示,会员中心这里的图标在小程序端显示异常。但是在网页端又是能够正常显示的。 小程序端截图: 网页端截图: 我的解决方法 检查使用的小程序版本,比如这里使用的是1.2.238版本的小程序,最后…