七叶笔记 » golang编程 » Gin源码剖析

Gin源码剖析

介绍

Gin 是一个 Golang 写的 web 框架,具有高性能的优点,基于 httprouter,它提供了类似martini但更好性能(路由性能约快40倍)的API服务。官方地址:。

使用

在项目中使用Gin也极其简单

  1. 下载gin: go get -u -v github.com/gin-gonic/gin
  2. import中引入”github.com/gin-gonic/gin”
  3. 核心代码r := gin.Default()r.GET(“/ping”, ping) r.Run(“:8080”)
  4. go run 后,浏览器输入即可使用
  5. 可以使用热加载调试 工具:go get -v -u github.com/pilu/fresh – 执行fresh即可,代码有变动会自动编译程序

下面为整体演示代码:

 package main
import (
  "net/http"
  ginSwagger "github.com/swaggo/gin-swagger"
  "github.com/swaggo/gin-swagger/swaggerFiles"
  _ "asap/docs"
  "github.com/gin-gonic/gin"
)
// @Summary 接口探活
// @Produce  json
// @Param lang query string false "en"
// @Success 200 {string} string "ok"
// @Router /ping [get]
func ping(c *gin.Context) {
  c.String(http.StatusOK, "ok")
}
func main() {
  r := gin.Default()
  r.GET("/ping", ping)
  r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))
  v1 := r.Group("/v1")
{
    v1.GET("/group", ping)
}
  // Listen and Server in 0.0.0.0:8080
  r.Run(":9090")
}  

源码剖析

Gin代码量很少,使用 find . -name “*.go” | xargs cat | wc -l 查看后,在14K左右。我会从5个方面来进行解析

  • 结构简介:Gin使用的结构进行简单说明
  • 前期准备:Gin是如何将路由等信息组合起来的
  • 监听请求:Gin是如何开启服务,监听请求的
  • 请求处理:当请求到达时,Gin如何处理这些请求
  • 返回数据:处理完请求后,如何将数据返回给请求方

本文只是做简单的剖析,方便大家能够快速地理解和学习这个框架。

相关结构和流程图可参考:

结构简介

本节主要给大家介绍一下Gin使用的核心数据结构或者接口,其中有些图画得不太准确,不过不影响理解。

  1. Engine:Engine里有三个非常重要的数据
  2. RouterGroup:使用Handlers存放中间件,另外提供设置路由的功能
  3. pool:主要用于从池中获取或者存放Context,减少GC
  4. trees:主要用于存放路由信息和该路由对应的处理函数列表,每个HTTP方法(GET POST等)都有单独的tree

  1. Context:主要接收server传递过来的http.Request和http.Response,并对这两个数据进行处理

四个流程

红色为前期准备,绿色为监听请求,紫色为请求处理,粉色为返回数据。如果图片不清晰,可查看

说明

  1. 学习完Gin框架,我们自己也可以制作简单的go-web框架。go在语言层面帮我们解决了很多重复性的工作,实在是一门有理想有追求的语言。
  2. 本文章只是简单的讲解,最好的剖析还是源码本身。

参考资料

使用

  1. Go Gin 简明教程
  2. 源码
  3. 中文文档
  4. gin中文文档

源码

  1. sync.Pool详解

相关文章