vmauth: fix vmauth_user_request_backend_errors_total metric calc logic for use case when only one backend is available - if we get an error from the retry_status_codes list, but cannot execute retry, we increment vmauth_user_request_backend_errors_total as well (#5688)

This commit is contained in:
Alexander Marshalov 2024-01-25 14:04:20 +01:00 committed by Aliaksandr Valialkin
parent bd7ebb41b2
commit ef4bb36d99
No known key found for this signature in database
GPG Key ID: 52C003EE2BCDB9EB

View File

@ -261,15 +261,20 @@ func tryProcessingRequest(w http.ResponseWriter, r *http.Request, targetURL *url
logger.Warnf("remoteAddr: %s; requestURI: %s; retrying the request to %s because of response error: %s", remoteAddr, req.URL, targetURL, err) logger.Warnf("remoteAddr: %s; requestURI: %s; retrying the request to %s because of response error: %s", remoteAddr, req.URL, targetURL, err)
return false return false
} }
if (rtbOK && rtb.canRetry()) && hasInt(retryStatusCodes, res.StatusCode) { if hasInt(retryStatusCodes, res.StatusCode) {
// Retry requests at other backends if it matches retryStatusCodes. if rtbOK && rtb.canRetry() {
// See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/4893 // Retry requests at other backends if it matches retryStatusCodes.
remoteAddr := httpserver.GetQuotedRemoteAddr(r) // See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/4893
// NOTE: do not use httpserver.GetRequestURI remoteAddr := httpserver.GetQuotedRemoteAddr(r)
// it explicitly reads request body, which may fail retries. // NOTE: do not use httpserver.GetRequestURI
logger.Warnf("remoteAddr: %s; requestURI: %s; retrying the request to %s because response status code=%d belongs to retry_status_codes=%d", // it explicitly reads request body, which may fail retries.
remoteAddr, req.URL, targetURL, res.StatusCode, retryStatusCodes) logger.Warnf("remoteAddr: %s; requestURI: %s; retrying the request to %s because response status code=%d belongs to retry_status_codes=%d",
return false remoteAddr, req.URL, targetURL, res.StatusCode, retryStatusCodes)
return false
}
// if we get an error from the retry_status_codes list, but cannot execute retry,
// we consider such a request an error as well
ui.backendErrors.Inc()
} }
removeHopHeaders(res.Header) removeHopHeaders(res.Header)
copyHeader(w.Header(), res.Header) copyHeader(w.Header(), res.Header)