大家好!我是 xcbeyond, xcbeyond 就是我,大家也可以叫我超哥!
1、Gin 概述
Gin 是一个基于 Go 语言编写的 Web 框架,与 martini 框架类似,但拥有更好的性能,借助高性能的 httprouter,速度提升了近 40 倍。如果你追求高性能和开发效率,你会爱上 Gin 框架。
1.1 功能特性
- 快速
- 基于Radox树(一种更节省空间的 Trie 树结构)的路由,内存占用更小。
- 没有反射。
- 可预测的 API 性能。
- 中间件支持
传入的 HTTP 请求可以由中间件链和最终操作处理。例如:Logger、Authorization、GZIP 以及最终的 DB 操作。 - Crash 处理
Gin 框架可以捕获一个发生在 HTTP 请求中的 panic 并 recover 它,从而保证服务器始终可用。此外,你还可以向 Sentry 报告这个 panic! - JSON 验证
Gin 可以解析和验证请求的 JSON,例如检查有个必须值是否存在。 - 路由分组
支持通过路由分组来更好地组织路由,例如是否需要授权、设置 API 的版本等,此外,这些分组可以无限制地嵌套而不会降低性能。 - 错误管理
Gin 框架提供了一种方便的机制来收集 HTTP 请求期间发生的所有错误,并且最终通过中间件将它们写入日志文件、数据库或者通过网络发送到其它系统。 - 内置渲染
Gin 框架提供了简单易上手的 API, 来返回 JSON、XML 或者 HTML 格式的响应。 - 可扩展
我们将会在后续示例代码中看到 Gin 框架非常容易扩展。
1.2 应用举例
以下项目都是使用 Gin 框架开发的:
- gorush:Go 编写的通知推送服务器。
- fnproject:容器原生,云 serverless 平台。
- photoprism:基于 Go 和 Google TensorFlow 实现的个人照片管理工具。
- krakend:拥有中间件的超高性能 API 网关。
- picfit:Go 编写的图像尺寸调整服务器。
- gotify:基于 WebSocket 进行实时消息收发的简单服务器。
- cds:企业级持续交付和 DevOps 自动化开源平台。
2、快速入门
2.1 安装
- 准备 Golang 环境
- 安装 Gin
go get -u github.com/gin-gonic/gin
2.2 示例
- 创建示例工程目录 gin-demo
- 新建
gin.go
源文件:
package main
import (
"github.com/gin-gonic/gin"
)
func main() {
// 初始化gin对象
g := gin.Default()
// 设置一个get请求,其URL为/hello,并实现简单的响应
g.GET("/hello", func(c *gin.Context) {
c.JSON(200, gin.H{
"message": "hello world!",
})
})
// 启动服务
g.Run()
}
- go mod 导入依赖
项目 gin-demo 目录下,执行go mod init gin-demo
和go mod tidy
命令完成依赖导入,将自动生产 go.mod 、go.sum 文件。
xcbeyond@xcbeyonddeMacBook-Pro gin-demo % go mod init gin-demo
go: creating new go.mod: module gin
go: to add module requirements and sums:
go mod tidy
xcbeyond@xcbeyonddeMacBook-Pro gin-demo % go mod tidy
go: finding module for package github.com/gin-gonic/gin
go: found github.com/gin-gonic/gin in github.com/gin-gonic/gin v1.7.3
go: downloading github.com/stretchr/testify v1.4.0
go: downloading github.com/go-playground/assert/v2 v2.0.1
go.mod:
module gin-demo
go 1.16
require github.com/gin-gonic/gin v1.7.3
- 运行
gin-demo 目录执行命令go run gin.go
启动 gin Web Server:
xcbeyond@xcbeyonddeMacBook-Pro gin-demo % go run gin.go
[GIN-debug] [WARNING] Creating an Engine instance with the Logger and Recovery middleware already attached.
[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.
- using env: export GIN_MODE=release
- using code: gin.SetMode(gin.ReleaseMode)
[GIN-debug] GET /hello --> main.main.func1 (3 handlers)
[GIN-debug] Environment variable PORT is undefined. Using port :8080 by default
[GIN-debug] Listening and serving HTTP on :8080
此时,Web Server 监听 8080 端口,访问 http://localhost:8080/hello, 则会响应:
{"message":"hello world!"}
3、总结
Gin 的入门很简单,简单几行代码就可以启动一个 Web Server,并且还有非常完善的组件等,接下来的文章将会对其一些细节展开具体说明。