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

字节跳动自研 HTTP 框架 Hertz

Hertz 是字节跳动自研的高性能 HTTP 框架,专为高并发、低延迟的场景设计。它基于 Go 语言开发,结合了字节跳动在微服务架构中的实践经验,旨在提供更高效的 HTTP 服务开发体验。
在这里插入图片描述


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 网关,提供统一的入口和路由。
  • 内部服务:用于构建高性能的内部微服务。
实时数据处理
  • 消息推送:支持实时消息推送服务。
  • 数据采集:用于高并发的数据采集和处理。

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.mzph.cn/diannao/67942.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实战演示:利用ChatGPT高效撰写论文

在当今学术界,撰写论文是一项必不可少的技能。然而,许多研究人员和学生在写作过程中常常感到困惑和压力。幸运的是,人工智能的快速发展为我们提供了新的工具,其中ChatGPT便是一个优秀的选择。本文将通过易创AI创作平台&#xff0c…

在线可编辑Excel

1. Handsontable 特点: 提供了类似 Excel 的表格编辑体验,包括单元格样式、公式计算、数据验证等功能。 支持多种插件,如筛选、排序、合并单元格等。 轻量级且易于集成到现有项目中。 具备强大的自定义能力,可以调整外观和行为…

Vue.js 渐进式增强:如何逐步为传统项目注入活力

Vue.js 是一个渐进式框架,这意味着你可以将它逐步引入到现有项目中,而无需彻底重构。渐进式增强特别适合那些已经在使用传统服务器渲染框架(如 PHP、Django、Laravel)的项目,为它们增加动态交互功能。本篇教程将介绍如…

重构(4)

(一)添加解释性变量,使得代码更容易理解,更容易调试,也可以方便功能复用 解释性的变量 总价格为商品总价(单价*数量)-折扣(超过100个以上的打9折)邮费(原价的…

某金融科技公司内腾讯专有云企业版TCE结合宁盾2FA双因子认证满足商用密码应用安全性评估

项目背景 金融行业数据安全至关重要,涉及国家经济安全和公民个人信息安全。监管机构为了确保金融体系的安全稳定,对金融机构的密码应用提出了严格要求。例如,国务院办公厅早在 2014 年发布的《金融领域密码应用指导意见》明确指出&#xff0c…

Seata进阶全文详解(集成Nacos及SpringCloud配置)

Seata 简介 在当今微服务架构盛行的时代,分布式系统中的事务管理成为了一个极具挑战性的问题。Seata(Simple Extensible Autonomous Transaction Architecture)应运而生,它是一款专为微服务架构设计的分布式事务解决方案&#xf…

spring-springboot -springcloud

目录 spring: 动态代理: spring的生命周期(bean的生命周期): SpringMvc的生命周期: SpringBoot: 自动装配: 自动装配流程: Spring中常用的注解: Spring Boot中常用的注解: SpringCloud: 1. 注册中心: 2. gateway(网关): 3. Ribbon(负载均…

STM32更新程序OTA

STM32的OTA(Over-The-Air)更新程序是一种通过无线通信方式,为设备分发新软件、配置甚至更新加密密钥的技术。以下是关于STM32 OTA更新程序的详细介绍: 一、OTA升级流程 STM32的OTA升级流程通常包括以下几个关键步骤:…

DAY9,递归实现计算 :1 + 1/3 - 1/5 + 1/7 - 1/9 + .... 1/n 的值

题目 用递归实现计算 :1 1/3 - 1/5 1/7 - 1/9 .... 1/n 的值,n通过键盘输入 思路 递进阶段:n、...... 、9、7、5、3、1 函数出口:递进到1 开始返回;函数返回值视为“总和” 回归阶段:对当前n取倒数;“总…

Formality:不可读(unread)的概念

相关阅读 Formalityhttps://blog.csdn.net/weixin_45791458/category_12841971.html?spm1001.2014.3001.5482https://blog.csdn.net/weixin_45791458/category_12841971.html?spm1001.2014.3001.5482 在Formality中有时会遇到不可读(unread)这个概念,本文就将对此…

【27】Word:徐雅雯-艺术史文章❗

目录 题目​ NO1.2 NO3 NO4 NO5 NO6.7 NO8.9 NO10.11 注意:修改样式的字体颜色/字号,若中英文一致,选择所有脚本。格式相似的文本→检查多选/漏选格式刷F4重复上一步操作请❗每一步检查和保存 题目 NO1.2 F12另存为布局→行号布局…

关于ARM和汇编语言

一图流 ARM 计算机组成 输入设备 输出设备 存储设备 运算器 控制器 处理器读取内存程序执行的过程 取指阶段:控制器器通过地址总线向存储器发送想要获取的指令的地址编号,存储器将指定的指令发送给处理器 译码阶段:控制器对指令进行分…

Ubuntu20.04 文件系统打不开

问题描述: 电脑中安装了相关的工具, 删除了一些东西之后,Linux 电脑操作系统为 Ubuntu20.04突然打不开文件系统了,命令 sudo nautilus 可以正常进入, 显示了很多权限问题。 使用过: killall nautilus 不起作用,后查原因:我无法作为普通用户…

oneplus3t-lineage-14编译-android7

lineageOS-14.1-oneplus3t-build.md lineageOS-14(android7)的开发者模式/usb调试(adb)有root功能, 而lineageOS-16(android9)无 oneplus3t-lineage-14编译-android7 1 清华linageos镜像 x lineage-14.1-20180223-nightly-oneplus3-signed.zip ntfs分区挂载为普通用户目录…

PyTorch使用教程(9)-使用profiler进行模型性能分析

1、简介 PyTorch Profiler是一个内置的性能分析工具,可以帮助开发者定位计算资源(如CPU、GPU)的瓶颈,从而更好地优化PyTorch程序。通过捕获和分析GPU的计算、内存和带宽利用情况,能够有效识别并解决性能瓶颈。 2、原…

2025-01-22 Unity Editor 1 —— MenuItem 入门

文章目录 1 Editor 文件夹2 MenuItem3 使用示例3.1 打开网址3.2 打开文件夹3.3 Menu Toggle3.4 Menu 代码复用3.5 MenuItem 激活与失活4 代码示例 1 Editor 文件夹 ​ Editor 文件夹是 Unity 中的特殊文件夹,Unity 中所有编辑器相关的脚本都需要放置在其中&#xf…

docker 安装 mysql 详解

在平常的开发工作中,我们经常需要用到 mysql 数据库。那么在docker容器中,应该怎么安装mysql数据库呢。简单来说,第一步:拉取镜像;第二步:创建挂载目录并设置 my.conf;第三步:启动容…

linux-samba服务配置与应用

1.了解samba的配置文件 2.熟悉samba服务的实例 以前我们在windows上共享文件的话,只需右击要共享的文件夹,然后选择共享相关的选项设置即可,然后如何实现windows和linux的文件共享呢,这就涉及到了samba服务,这个软件…

Spring Boot 整合 Redis 步骤详解

文章目录 1. 引言2. 添加依赖3. 配置 Redis 连接信息4. 创建 Redis 操作服务类5. 使用 RedisTemplate 或 ReactiveRedisTemplate6. 测试 Redis 功能7. 注意事项8. 总结 Redis 是一个高性能的键值存储系统,常用于缓存、消息队列等多种场景。将 Redis 与 Spring Boot …

缓存商品、购物车(day07)

缓存菜品 问题说明 问题说明:用户端小程序展示的菜品数据都是通过查询数据库获得,如果用户端访问量比较大,数据库访问压力随之增大。 结果: 系统响应慢、用户体验差 实现思路 通过Redis来缓存菜品数据,减少数据库查询…