使用中间件实现HTTP请求统计,通过StatsMiddleware记录请求数和耗时,结合atomic.LoadInt64保证并发安全,并暴露/stats接口返回统计信息,可扩展支持路径、方法分类及状态码捕获。

在Go语言中实现HTTP请求统计功能,通常可以通过中间件(Middleware)的方式,在不侵入业务逻辑的前提下,对所有进入的HTTP请求进行拦截和统计。下面介绍一种简单、实用的实现方式。
使用中间件记录请求数据
中间件是实现HTTP请求统计的核心。它在每个请求处理前和处理后执行一些额外逻辑,比如记录请求数、响应时间、状态码等。
定义一个计数器变量和简单的结构体来保存统计信息:
var requestCount int64
然后编写一个中间件函数:
立即学习“go语言免费学习笔记(深入)”;
func StatsMiddleware(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
requestCount++
startTime := time.Now()
next.ServeHTTP(w, r)
duration := time.Since(startTime)
log.Printf(“%s %s %v”, r.Method, r.URL.Path, duration)
})
}
这个中间件递增请求数,并打印每个请求的处理耗时。
暴露统计接口
为了让外部能查看统计数据,可以添加一个专门的HTTP接口返回当前统计值:
帝国网站管理系统 v6.5 数据字典
该系统由帝国开发工作组独立开发,是一个经过完善设计的适用于Linux/windows/Unix等环境下高效的网站解决方案。从帝国新闻系统1.0版至今天的帝国网站管理系统,它的功能进行了数次飞跃性的革新,使得网站的架设与管理变得极其轻松。它采用了系统模型功能:用户通过此功能可直接在后台扩展与实现各种系统,如产品、房产、供求、等等系统,因此特性,[1] 帝国CMS又被誉为“万能建站工具”;采用了
407 查看详情
func HandleStats(w http.ResponseWriter, r *http.Request) {
w.Header().Set(“Content-Type”, “application/json”)
json.NewEncoder(w).Encode(map[string]interface{}{
“requests”: atomic.LoadInt64(&requestCount),
})
}
注意这里使用 atomic.LoadInt64 是为了保证并发安全,因为多个goroutine可能同时访问计数器。
集成到HTTP服务
将中间件应用到你的路由上。例如使用标准库的 net/http:
mux := http.NewServeMux()
mux.HandleFunc(“/stats”, HandleStats)
mux.HandleFunc(“/”, HomeHandler)
使用中间件包装整个mux:
loggedMux := StatsMiddleware(mux)
http.ListenAndServe(“:8080”, loggedMux)
这样所有经过mux的请求都会被统计。
增强功能建议
按路径、方法分类统计:可用 map[string]int 统计不同URL的访问次数 记录状态码分布:自定义 ResponseWriter 包装以捕获写入的状态码 定时输出或上报指标:结合 prometheus 客户端库可实现更专业的监控 使用原子操作或 sync.Mutex 保护共享变量,避免竞态条件
基本上就这些。通过中间件机制,Golang能很简洁地实现HTTP请求统计,既不影响业务代码,又具备良好的扩展性。
以上就是Golang如何实现HTTP请求统计功能的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1134157.html
微信扫一扫
支付宝扫一扫