lib/storage: tune updating a map with today`s metric ids

- Increase update iterval from 1s to 10s. This should reduce CPU usage
  for large amounts of metric ids with constant churn.
- Reduce pendingTodayMetricIDsLock lock duration during the update.
This commit is contained in:
Aliaksandr Valialkin 2019-06-02 21:58:14 +03:00
parent e27fd5148a
commit a2986cde70

View file

@ -360,15 +360,17 @@ func (s *Storage) startTodayMetricIDsUpdater() {
}()
}
var todayMetricIDsUpdateInterval = time.Second * 10
func (s *Storage) todayMetricIDsUpdater() {
t := time.NewTimer(time.Second)
t := time.NewTimer(todayMetricIDsUpdateInterval)
for {
select {
case <-s.stop:
return
case <-t.C:
s.updateTodayMetricIDs()
t.Reset(time.Second)
t.Reset(todayMetricIDsUpdateInterval)
}
}
}
@ -766,20 +768,20 @@ func (s *Storage) updateTodayMetricIDs() {
return
}
// Slow path tm.m must be updated with non-empty s.pendingTodayMetricIDs.
// Slow path: tm.m must be updated with non-empty s.pendingTodayMetricIDs.
m := make(map[uint64]struct{}, len(tm.m)+newMetricIDsLen)
if tm.date == today {
for metricID := range tm.m {
m[metricID] = struct{}{}
}
}
s.pendingTodayMetricIDsLock.Lock()
for metricID := range s.pendingTodayMetricIDs {
newMetricIDs := s.pendingTodayMetricIDs
s.pendingTodayMetricIDs = make(map[uint64]struct{}, len(newMetricIDs))
s.pendingTodayMetricIDsLock.Unlock()
for metricID := range newMetricIDs {
m[metricID] = struct{}{}
}
s.pendingTodayMetricIDs = make(map[uint64]struct{}, len(s.pendingTodayMetricIDs))
s.pendingTodayMetricIDsLock.Unlock()
tmNew := &todayMetricIDs{
m: m,