Go to file
CloudWeGo.ice () cbb35589cb
Update README.md (#54)
feat: replace QRcode_en with QRcode_cn, cuz English version of WeCom has some unpredictable bugs
2022-06-14 11:26:15 +08:00
.github Initial commit 2022-05-31 15:34:58 +08:00
examples/standard Initial commit 2022-05-31 15:34:58 +08:00
images docs(readme.md):add wechat-group-qrcode image 2022-06-08 12:16:35 +08:00
internal Initial commit 2022-05-31 15:34:58 +08:00
licenses Initial commit 2022-05-31 15:34:58 +08:00
pkg refactor: omit redundant nil check around loop (#52) 2022-06-10 10:38:32 +08:00
script Initial commit 2022-05-31 15:34:58 +08:00
.gitignore Initial commit 2022-05-31 15:34:58 +08:00
.licenserc.yaml Initial commit 2022-05-31 15:34:58 +08:00
CODE_OF_CONDUCT.md Initial commit 2022-05-31 15:34:58 +08:00
CONTRIBUTING.md Initial commit 2022-05-31 15:34:58 +08:00
LICENSE Initial commit 2022-05-31 15:34:58 +08:00
Makefile Initial commit 2022-05-31 15:34:58 +08:00
NOTICE Initial commit 2022-05-31 15:34:58 +08:00
README.md Update README.md (#54) 2022-06-14 11:26:15 +08:00
README_cn.md docs(readme.md):add wechat-group-qrcode image 2022-06-08 12:16:35 +08:00
ROADMAP.md Initial commit 2022-05-31 15:34:58 +08:00
_typos.toml Initial commit 2022-05-31 15:34:58 +08:00
go.mod Initial commit 2022-05-31 15:34:58 +08:00
go.sum Initial commit 2022-05-31 15:34:58 +08:00
version.go Initial commit 2022-05-31 15:34:58 +08:00

README.md

Hertz

English | 中文

Hertz [həːts] is a high-usability, high-performance and high-extensibility Golang HTTP framework that helps developers build microservices. It was designed with reference to other open-source frameworks like fasthttpginecho and combined with the internal requirements in ByteDance. At present, it has been widely used inside ByteDance. Nowadays, more and more microservices use Golang. If you have requirements for microservice performance and hope that the framework can fully meet the internal customizable requirements, Hertz will be a good choice.

Basic Features

  • High usability

    During the development process, it is often more important to write the correct code quickly. Therefore, in the iterative process of Hertz, we actively listen to users' opinions and continue to polish the framework, hoping to provide users with a better user experience and help users write correct code faster.

  • High performance

    Hertz uses the self-developed high-performance network library Netpoll by default. In some special scenarios, compared to Go Net, Hertz has certain advantages in QPS and time delay. For performance data, please refer to the Echo data in the figure below. Performance For detailed performance data, please refer to hertz-benchmark.

  • High extensibility

    Hertz adopts a layered design, providing more interfaces and default extension implementations. Users can also extend by themselves. At the same time, thanks to the layered design of the framework, the extensibility of the framework will be much greater. At present, only stable capabilities are open-sourced to the community. More planning refers to RoadMap.

  • Multi-protocol support

    The Hertz framework provides HTTP1.1, ALPN protocol support natively. In addition, due to the layered design, Hertz even supports custom build protocol resolution logic to meet any needs of protocol layer extensions.

  • Network layer switching capability

    Hertz implements the function to switch between Netpoll and Go Net on demand. Users can choose the appropriate network library for different scenarios. And Hertz also supports the extension of network library in the form of plug-ins .

Documentation

Getting Started

Example

The Hertz-Examples repository provides code out of the box. more

Basic Features

Contains introduction and use of general middleware, context selection, data binding, data rendering, direct access, logging, error handling. more

Service Governance

Contains tracer monitor. more

Framework Extension

Contains network library extensions. more

Reference

Apidoc, framework configurable items list. more

FAQ

Frequently Asked Questions. more

Performance

Performance testing can only provide a relative reference. In production, there are many factors that can affect actual performance. We provide the hertz-benchmark project to track and compare the performance of Hertz and other frameworks in different situations for reference.

  • Netpoll: A high-performance network library. Hertz integrated by default.
  • Hertz-Contrib: A partial extension library of Hertz, which users can integrate into Hertz through options according to their needs.
  • Example: Use examples of Hertz.

Blogs

Contributing

Contributing

RoadMap

Hertz RoadMap

License

Hertz is distributed under the Apache License, version 2.0. The licenses of third party dependencies of Hertz are explained here.

Community

LarkGroup

  • Wechat: CloudWeGo community wechat group.

    WechatGroup

Landscapes

  

CloudWeGo enriches the CNCF CLOUD NATIVE Landscape.