1.Gin源码分析 - 中间件(5)- Recovery
2.gin框架原理详解(gin框架是层源什么)
3.Go性能分析工具:pprof
Gin源码分析 - 中间件(5)- Recovery
Recovery中间件在HTTP请求处理中扮演着关键角色,尤其在处理过程中产生panic时。码g码它能够捕获并处理这些异常,层源确保服务的码g码稳定性和客户端的正常响应。通过使用gin框架,层源可以通过两种方式集成Recovery中间件:第一种是码g码逗友娱乐源码直接调用gin.New创建引擎时,无需注册Recovery中间件;第二种是层源在调用gin.Default()创建引擎时,内部自动注册Recovery中间件。码g码在没有使用Recovery中间件的层源情况下,向服务发送异常请求会导致服务端和客户端出现异常;而使用Recovery中间件后,码g码异常被捕获并以友好的层源方式显示异常堆栈,同时客户端收到HTTP 错误。码g码
Recovery中间件内部实现通过多种变体接口实现,层源包括CustomRecoveryWithWriter、码g码死机源码RecoveryWithWriter、层源CustomRecovery以及Recovery。其中,CustomRecoveryWithWriter提供最底层的形式,允许用户自定义异常输出和恢复处理逻辑。RecoveryWithWriter则提供了Writer参数和一个可选的RecoveryFunc,如果没有定义该函数,则使用defaultHandleRecovery。CustomRecovery和Recovery则分别使用默认的DefaultErrorWriter和defaultHandleRecovery。
Recovery的核心实现通过DefaultErrorWriter和defaultHandleRecovery两个主要部分。DefaultErrorWriter负责设置日志格式为红色字体输出。defaultHandleRecovery方法是整个处理流程的核心,包含捕获、tair 源码处理异常、生成响应等关键步骤。首先通过recover()方法获取panic信息,判断异常是否由客户端断开连接引起,然后获取异常堆栈、请求头,并根据异常类型和原因进行相应的处理和响应输出。最终,根据处理结果返回HTTP响应,如果是异常则返回HTTP ,如果是网络原因则使用Abort方法。
Recovery中间件的实现不仅提供了异常处理的灵活性,还确保了服务的delaunay源码稳定性和客户端的友好体验。通过捕获和处理异常,Recovery中间件能够有效地减少服务中断的可能性,提高系统的健壮性。总结而言,Recovery中间件在处理异常时提供了实用的方法,对于开发稳定、可靠的HTTP服务具有重要意义。
gin框架原理详解(gin框架是什么)
Gin的启动过程、路由及上下文源码解读
Engine是gin框架的一个实例,它包含了多路复用器、中间件和配置中心。
gin通过Engine.Run(addr...string)来启动服务,最终调用的oflademo 源码是/手败gin-gonic/gin
一个简单的例子:
packagemain
import"github.com/gin-gonic/gin"
funcmain(){
//Default返回一个默认的路由引擎
r:=gin.Default()
r.GET("/ping",func(c*gin.Context){
//输出json结果给调用方
c.JSON(,gin.H{
"message":"pong",
})
})
r.Run()//listenandserveon0.0.0.0:
}
编译运行程序,打开浏览器,访问页面显示:
{ "message":"pong"}
gin的功能不只是简单输出Json数据。它是一个轻量级的WEB框架,支持RestFull风格API,支持GET,POST,PUT,PATCH,DELETE,OPTIONS等/gin-gonic/gin"
)
funcmain(){
router:=gin.Default()
//静态资源加载,本例为css,js以及资源
router.StaticFS("/public",/ffhelicopter/tmm/website/static"))
router.StaticFile("/favicon.ico","./resources/favicon.ico")
//Listenandserveon0.0.0.0:
router.Run(":")
}
首先需要是生成一个Engine,这是gin的核心,默认带有Logger和Recovery两个中间件。
router:=gin.Default()
StaticFile是加载单个文件,而StaticFS是加载一个完整的目录资源:
func(group*RouterGroup)StaticFile(relativePath,filepathstring)IRoutes
func(group*RouterGroup)StaticFS(relativePathstring,fs/gin-gonic/gin
如果安装失败,直接去Githubclone下来,放置到对应的目录即可。
(2)代码中使用:
下面是一个使用Gin的简单例子:
packagemain
import(
"github.com/gin-gonic/gin"
)
funcmain(){
router:=gin.Default()
router.GET("/ping",func(c*gin.Context){
c.JSON(,gin.H{
"message":"pong",
})
})
router.Run(":")//listenandserveon0.0.0.0:
}
简单几行代码,就能实现一个web服务。使用gin的Default方法创建一个路由handler。然后通过HTTP方法绑定路由规则和路由函数。不同于net/e"}。
注:Gin还包含更多的返回方法如c.String,c.HTML,c.XML等,请自行了解。可以方便的返回HTML数据
我们在之前的组v1路由下新定义一个路由:
下面我们访问
可以看到,通过c.Param(“key”)方法,Gin成功捕获了url请求路径中的参数。同理,gin也可以捕获常规参数,如下代码所示:
在浏览器输入以下代码:
通过c.Query(“key”)可以成功接收到url参数,c.DefaultQuery在参数不存在的情况下,会由其默认值代替。
我们还可以为Gin定义一些默认路由:
这时候,我们访问一个不存在的页面:
返回如下所示:
下面我们测试在Gin里面使用Post
在测试端输入:
附带发送的数据,测试即可。记住需要使用POST方法.
继续修改,将PostHandler的函数修改如下
测试工具输入:
发送的内容输入:
返回结果如下:
备注:此处需要指定Content-Type为application/x-www-form-urlencoded,否则识别不出来。
一定要选择对应的PUT或者DELETE方法。
Gin框架快速的创建路由
能够方便的创建分组
支持url正则表达式
支持参数查找(c.Paramc.Queryc.PostForm)
请求方法精准匹配
支持处理
快速的返回给客户端数据,常用的c.Stringc.JSONc.Data
Go性能分析工具:pprof
Go性能分析工具:pprof
pprof,全称为profile,是Go语言中广泛使用的性能分析工具。其具备可视化、原生集成、易于上手等优点。通过命令行工具go tool pprof,用户可以对数据进行交互式分析或生成web可视化页面,甚至导出为svg格式。pprof提供了九种分析方式,其中使用最频繁的包括内存分析、CPU分析、阻塞分析和互斥锁分析。
在性能分析过程中,pprof的使用方法分为工具型应用和服务型应用两种。工具型应用通过导入runtime/pprof库,手动将CPU、内存信息记录到文件中。服务型应用则利用net//gin-contrib/...。导入该包后,无需额外配置,即可实现服务的pprof路由注册。net/http/pprof包的实现通过注册路由自动完成,而gin框架的集成则通过该包提供的封装函数实现。
在数据分析方面,pprof提供了多种工具帮助用户理解资源消耗。如TOP图用于查看CPU占用率最高的接口,函数调用图揭示内存消耗较多的函数,火焰图提供整体时间/内存消耗的直观视图,Peek图和Go源码分析图则帮助定位具体问题,汇编代码分析图则提供了更底层的分析视角。
pprof的使用方法和分析策略对于优化Go应用程序性能至关重要。了解其功能和应用,可以帮助开发者更有效地定位和解决问题,提升应用性能。