lib/storage: properly update link for entry at dateMetricID cache (#4258)

previously during sync for mutable and immutable cache parts, link for hotEntry with current date may be not properly updated
it corrupts cache for backfilling metrics and increased cpu load
This commit is contained in:
Nikolay 2023-05-06 06:45:47 +02:00 committed by GitHub
parent 4e71003620
commit 8f4de6fa47
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -2162,10 +2162,14 @@ func (dmc *dateMetricIDCache) syncLocked() {
}
v = v.Clone()
v.Union(&e.v)
byDateMutable.m[date] = &byDateMetricIDEntry{
dme := &byDateMetricIDEntry{
date: date,
v: *v,
}
if date == byDateMutable.hotEntry.Load().(*byDateMetricIDEntry).date {
byDateMutable.hotEntry.Store(dme)
}
byDateMutable.m[date] = dme
}
for date, e := range byDate.m {
v := byDateMutable.get(date)