Throttle scraping if a scrape took longer than the configured interval.

The simple algorithm applied here will increase the actual interval
incrementally, whenever and as long as the scrape itself takes longer
than the configured interval. Once it takes shorter again, the actual
interval will iteratively decrease again.
This commit is contained in:
beorn7 2015-02-06 16:44:56 +01:00
parent d2ab49c396
commit 5678a86924

View file

@ -265,10 +265,18 @@ func (t *target) RunScraper(ingester extraction.Ingester, interval time.Duration
case <-t.scraperStopping: case <-t.scraperStopping:
return return
case <-ticker.C: case <-ticker.C:
targetIntervalLength.WithLabelValues(interval.String()).Observe(float64(time.Since(t.lastScrape) / time.Second)) took := time.Since(t.lastScrape)
t.Lock() // Write t.lastScrape requires locking. t.Lock() // Write t.lastScrape requires locking.
t.lastScrape = time.Now() t.lastScrape = time.Now()
t.Unlock() t.Unlock()
targetIntervalLength.WithLabelValues(interval.String()).Observe(
float64(took) / float64(time.Second), // Sub-second precision.
)
// Throttle the scrape if it took longer than interval - by
// sleeping for the time it took longer. This will make the
// actual scrape interval increase as long as a scrape takes
// longer than the interval we are aiming for.
time.Sleep(took - interval)
t.scrape(ingester) t.scrape(ingester)
} }
} }