• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

HTTP框架:Hertz

武飞扬头像
SakurajiMayi
帮助1

1.介绍

Hertz 是字节跳动服务框架团队研发的超大规模的企业级微服务 HTTP 框架,具有高易用性、易扩展、低时延等特点。在经过了字节跳动内部一年多的使用和迭代后,如今已在 CloudWeGo 正式开源。目前,Hertz 已经成为了字节跳动内部最大的 HTTP 框架,线上接入的服务数量超过 1 万,峰值 QPS 超过 4 千万。除了各个业务线的同学使用外,也服务于内部很多基础组件,如:函数计算平台 FaaS、压测平台、各类网关、Service Mesh 控制面等,均收到不错的使用反馈。在如此大规模的场景下,Hertz 拥有极强的稳定性和性能,在内部实践中某些典型服务,如框架占比较高的服务、网关等服务,迁移 Hertz 后相比 Gin 框架,资源使用显著减少,CPU 使用率随流量大小降低 30%—60%,时延也有明显降低。

Hertz 坚持内外维护一套代码,为开源使用提供了强有力的保障。通过开源, Hertz 也将丰富云原生的 Golang字节跳动开源 Go HTTP 框架 Hertz 设计实践字节跳动开源 Go HTTP 框架 Hertz 设计实践字节跳动开源 Go HTTP 框架 Hertz 设计实践 中间件体系,完善 CloudWeGo 生态矩阵,为更多开发者和企业搭建云原生化的大规模分布式系统,提供一种现代的、资源高效的的技术方案。

框架设计

Hertz 设计之初调研了大量业界优秀的 HTTP 框架,同时参考了近年来内部实践中积累的经验。为了保证框架整体上满足:1. 极致性能优化的可能性;2. 面对未来不可控需求的扩展能力, Hertz 采用了 4 层分层设计,保证各个层级功能内聚,同时通过层级之间的接口达到灵活扩展的目标。

学新通

2.安装Hertz框架

安装命令

go install github.com/cloudwego/hertz/cmd/hz@latest

验证Hertz工具是否安装成功

hz -v

输出Hertz命令行工具版本

hz version v0.6.5

3.新建输出Hertz项目

创建项目后,执行hz new -mod hertz_demo初始化项目,项目初始化后,hertz会自动创建对应项目文件,文件结构如下:

├── biz
│   ├── handler
│   │   └── ping.go
│   └── router
│       └── register.go
├── go.mod
├── main.go
├── router.go
└── router_gen.go

4.运行Hertz项目

执行go mod tidy整理项目,运行main.go

package main

import (
   "context"
   "github.com/cloudwego/hertz/pkg/app"
   "github.com/cloudwego/hertz/pkg/app/server"
)

func main() {
   h := server.New()

   h.POST(" /sis", func(c context.Context, ctx *app.RequestContext) {
      ctx.Data(200, "text/plain; charset=utf-8", []byte("OK"))
   })

   h.Spin()
}

此时控制台输出如下:

2023/08/07 19:34:36.981886 engine.go:617: [Debug] HERTZ: Method=POST   absolutePath=/ /sis                    --> handlerName=main.main.func1 (num=1 handlers)
2023/08/07 19:34:36.991740 engine.go:389: [Info] HERTZ: Using network library=standard
2023/08/07 19:34:36.992797 transport.go:65: [Info] HERTZ: HTTP server listening on address=[::]:8888

启动后访问对接口进行测试

curl http://127.0.0.1:8888/ping

输出结果为:$ {"message":"pong"}

部分内容引用自blog.csdn.net/weixin_4418…

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgbachg
系列文章
更多 icon
同类精品
更多 icon
继续加载