From 8ca9c1783c09c3cf2424475f26fd1d6d7284be2f Mon Sep 17 00:00:00 2001 From: Giulio Eulisse <10544+ktf@users.noreply.github.com> Date: Tue, 5 Mar 2024 09:35:26 +0100 Subject: [PATCH] DPL CCDB: handle the Cache-Valid-Until header This will not recheck the etag and consider the cache valid until the timestamp in milliseconds in the Cache-Valid-Until is not passed by the data timestamp. --- Framework/CCDBSupport/src/CCDBHelpers.cxx | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/Framework/CCDBSupport/src/CCDBHelpers.cxx b/Framework/CCDBSupport/src/CCDBHelpers.cxx index 837b20cf4262b..37c4affe2877e 100644 --- a/Framework/CCDBSupport/src/CCDBHelpers.cxx +++ b/Framework/CCDBSupport/src/CCDBHelpers.cxx @@ -33,6 +33,8 @@ namespace o2::framework struct CCDBFetcherHelper { struct CCDBCacheInfo { std::string etag; + size_t cacheValidUntil = 0; + size_t cachePopulatedAt = 0; size_t cacheMiss = 0; size_t cacheHit = 0; size_t minSize = -1ULL; @@ -176,6 +178,11 @@ auto getOrbitResetTime(o2::pmr::vector const& v) -> Long64_t return (*ctp)[0]; }; +bool isOnlineRun(DataTakingContext const& dtc) +{ + return dtc.deploymentMode == DeploymentMode::OnlineAUX || dtc.deploymentMode == DeploymentMode::OnlineDDS || dtc.deploymentMode == DeploymentMode::OnlineECS; +} + auto populateCacheWith(std::shared_ptr const& helper, int64_t timestamp, TimingInfo& timingInfo, @@ -186,6 +193,8 @@ auto populateCacheWith(std::shared_ptr const& helper, int objCnt = -1; // We use the timeslice, so that we hook into the same interval as the rest of the // callback. + static bool isOnline = isOnlineRun(dtc); + auto sid = _o2_signpost_id_t{(int64_t)timingInfo.timeslice}; O2_SIGNPOST_START(ccdb, sid, "populateCacheWith", "Starting to populate cache with CCDB objects"); for (auto& route : helper->routes) { @@ -217,7 +226,14 @@ auto populateCacheWith(std::shared_ptr const& helper, const auto url2uuid = helper->mapURL2UUID.find(path); if (url2uuid != helper->mapURL2UUID.end()) { etag = url2uuid->second.etag; - checkValidity = std::abs(int(timingInfo.tfCounter - url2uuid->second.lastCheckedTF)) >= chRate; + // We check validity every chRate timeslices or if the cache is expired + uint64_t validUntil = url2uuid->second.cacheValidUntil; + // When the cache was populated. If the cache was populated after the timestamp, we need to check validity. + uint64_t cachePopulatedAt = url2uuid->second.cachePopulatedAt; + // If timestamp is before the time the element was cached or after the claimed validity, we need to check validity, again + // when online. + bool cacheExpired = (validUntil <= timestamp) && (timestamp <= cachePopulatedAt); + checkValidity = (std::abs(int(timingInfo.tfCounter - url2uuid->second.lastCheckedTF)) >= chRate) && (isOnline || cacheExpired); } else { checkValidity = true; // never skip check if the cache is empty } @@ -240,6 +256,7 @@ auto populateCacheWith(std::shared_ptr const& helper, helper->mapURL2UUID[path].lastCheckedTF = timingInfo.tfCounter; if (etag.empty()) { helper->mapURL2UUID[path].etag = headers["ETag"]; // update uuid + helper->mapURL2UUID[path].cachePopulatedAt = timestamp; helper->mapURL2UUID[path].cacheMiss++; helper->mapURL2UUID[path].minSize = std::min(v.size(), helper->mapURL2UUID[path].minSize); helper->mapURL2UUID[path].maxSize = std::max(v.size(), helper->mapURL2UUID[path].maxSize); @@ -251,6 +268,7 @@ auto populateCacheWith(std::shared_ptr const& helper, if (v.size()) { // but should be overridden by fresh object // somewhere here pruneFromCache should be called helper->mapURL2UUID[path].etag = headers["ETag"]; // update uuid + helper->mapURL2UUID[path].cachePopulatedAt = timestamp; helper->mapURL2UUID[path].cacheMiss++; helper->mapURL2UUID[path].minSize = std::min(v.size(), helper->mapURL2UUID[path].minSize); helper->mapURL2UUID[path].maxSize = std::max(v.size(), helper->mapURL2UUID[path].maxSize); @@ -260,6 +278,9 @@ auto populateCacheWith(std::shared_ptr const& helper, // one could modify the adoptContainer to take optional old cacheID to clean: // mapURL2DPLCache[URL] = ctx.outputs().adoptContainer(output, std::move(outputBuffer), DataAllocator::CacheStrategy::Always, mapURL2DPLCache[URL]); continue; + } else { + // Only once the etag is actually used, we get the information on how long the object is valid + helper->mapURL2UUID[path].cacheValidUntil = headers["Cache-Valid-Until"].empty() ? 0 : std::stoul(headers["Cache-Valid-Until"]); } } // cached object is fine