使用中间件实现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接口返回当前统计值:
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可能同时访问计数器。
将中间件应用到你的路由上。例如使用标准库的 net/http:
mux := http.NewServeMux()
mux.HandleFunc("/stats", HandleStats)
mux.HandleFunc("/", HomeHandler)
使用中间件包装整个mux:
loggedMux := StatsMiddleware(mux)
http.ListenAndServe(":8080", loggedMux)
这样所有经过mux的请求都会被统计。
基本上就这些。通过中间件机制,Golang能很简洁地实现HTTP请求统计,既不影响业务代码,又具备良好的扩展性。
以上就是Golang如何实现HTTP请求统计功能的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号