1
0
Fork 0
mirror of https://github.com/portainer/portainer.git synced 2025-07-24 15:59:41 +02:00

fix(docker-proxy): reduce DB writes to optimize the proxy calls EE-5516 (#9148)

This commit is contained in:
andres-portainer 2023-07-05 09:25:05 -03:00 committed by GitHub
parent b37120802e
commit 74515f102d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 61 additions and 73 deletions

View file

@ -0,0 +1,36 @@
package middlewares
import (
"net/http"
"time"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
)
func WithSlowRequestsLogger(next http.Handler) http.Handler {
if zerolog.GlobalLevel() > zerolog.DebugLevel {
return next
}
burstSampler := &zerolog.BurstSampler{
Burst: 1,
Period: time.Minute,
}
log := log.With().Logger().Sample(burstSampler)
return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
t0 := time.Now()
next.ServeHTTP(w, req)
if d := time.Since(t0); d > 100*time.Millisecond {
log.Debug().
Dur("elapsed_ms", d).
Str("method", req.Method).
Str("url", req.URL.String()).
Msg("slow request")
}
})
}