From 424068f8040048fc64c8e202f08d54d6ece43ddd Mon Sep 17 00:00:00 2001 From: Aliaksandr Valialkin Date: Tue, 28 Apr 2020 02:13:02 +0300 Subject: [PATCH] lib/promscrape: handle connection reset when targets responds with http redirect --- lib/promscrape/client.go | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/lib/promscrape/client.go b/lib/promscrape/client.go index 5a47861ad9..0cfb342877 100644 --- a/lib/promscrape/client.go +++ b/lib/promscrape/client.go @@ -80,7 +80,17 @@ func (c *client) ReadData(dst []byte) ([]byte, error) { } resp := fasthttp.AcquireResponse() err := doRequestWithPossibleRetry(c.hc, req, resp) - + statusCode := resp.StatusCode() + if statusCode == fasthttp.StatusMovedPermanently || statusCode == fasthttp.StatusFound { + // Allow a single redirect. + // It is expected that the redirect is made on the same host. + // Otherwise it won't work. + if location := resp.Header.Peek("Location"); len(location) > 0 { + req.URI().UpdateBytes(location) + err = c.hc.Do(req, resp) + statusCode = resp.StatusCode() + } + } fasthttp.ReleaseRequest(req) if err != nil { fasthttp.ReleaseResponse(resp) @@ -103,7 +113,6 @@ func (c *client) ReadData(dst []byte) ([]byte, error) { } else { dst = append(dst, resp.Body()...) } - statusCode := resp.StatusCode() if statusCode != fasthttp.StatusOK { metrics.GetOrCreateCounter(fmt.Sprintf(`vm_promscrape_scrapes_total{status_code="%d"}`, statusCode)).Inc() return dst, fmt.Errorf("unexpected status code returned when scraping %q: %d; expecting %d; response body: %q", @@ -124,15 +133,6 @@ var ( func doRequestWithPossibleRetry(hc *fasthttp.HostClient, req *fasthttp.Request, resp *fasthttp.Response) error { // There is no need in calling DoTimeout, since the timeout must be already set in hc.ReadTimeout. err := hc.Do(req, resp) - if err == nil && (resp.Header.StatusCode() == 301 || resp.Header.StatusCode() == 302) { - l := string(resp.Header.Peek("Location")) - if l != "" { - req.URI().Update(l) - // only redirect once - err = hc.Do(req, resp) - } - } - if err == nil { return nil }