From c116d1e9135b7a7f36338a33e5e02a4ab228c393 Mon Sep 17 00:00:00 2001 From: Suman Kumar Date: Tue, 11 Oct 2022 10:03:19 -0700 Subject: [PATCH] swss: Fixing race condition for rif counters * Fixing issue #11621 * The cleanup code for stale rif counters are now moved to syncd . Earlier as part of fix for issue #2193 the cleanup for stale rif counters was added. * But it could create a race condition between orchagent removes RIF rate counters from DB and lua script fetching them. * So as a fix all such cleanup has been moved to syncd. Signed-off-by: Suman Kumar --- orchagent/intfsorch.cpp | 35 ----------------------------------- orchagent/intfsorch.h | 4 ---- 2 files changed, 39 deletions(-) diff --git a/orchagent/intfsorch.cpp b/orchagent/intfsorch.cpp index 595ec72923..adc2aac9f4 100644 --- a/orchagent/intfsorch.cpp +++ b/orchagent/intfsorch.cpp @@ -1277,7 +1277,6 @@ bool IntfsOrch::removeRouterIntfs(Port &port) const auto id = sai_serialize_object_id(port.m_rif_id); removeRifFromFlexCounter(id, port.m_alias); - cleanUpRifFromCounterDb(id, port.m_alias); sai_status_t status = sai_router_intfs_api->remove_router_interface(port.m_rif_id); if (status != SAI_STATUS_SUCCESS) @@ -1500,45 +1499,11 @@ void IntfsOrch::removeRifFromFlexCounter(const string &id, const string &name) SWSS_LOG_DEBUG("Unregistered interface %s from Flex counter", name.c_str()); } -/* - TODO A race condition can exist when swss removes the counter from COUNTERS DB - and at the same time syncd is inserting a new entry in COUNTERS DB. Therefore - all the rif counters cleanup code should move to syncd -*/ -void IntfsOrch::cleanUpRifFromCounterDb(const string &id, const string &name) -{ - SWSS_LOG_ENTER(); - string counter_key = getRifCounterTableKey(id); - string rate_key = getRifRateTableKey(id); - string rate_init_key = getRifRateInitTableKey(id); - m_counter_db->del(counter_key); - m_counter_db->del(rate_key); - m_counter_db->del(rate_init_key); - SWSS_LOG_NOTICE("CleanUp interface %s oid %s from counter db", name.c_str(),id.c_str()); -} - string IntfsOrch::getRifFlexCounterTableKey(string key) { return string(RIF_STAT_COUNTER_FLEX_COUNTER_GROUP) + ":" + key; } -string IntfsOrch::getRifCounterTableKey(string key) -{ - return "COUNTERS:" + key; -} - -string IntfsOrch::getRifRateTableKey(string key) -{ - return "RATES:" + key; -} - -string IntfsOrch::getRifRateInitTableKey(string key) -{ - return "RATES:" + key + ":RIF"; -} - - - void IntfsOrch::generateInterfaceMap() { m_updateMapsTimer->start(); diff --git a/orchagent/intfsorch.h b/orchagent/intfsorch.h index ba28c8dde6..6b4942897e 100644 --- a/orchagent/intfsorch.h +++ b/orchagent/intfsorch.h @@ -93,10 +93,6 @@ class IntfsOrch : public Orch unique_ptr m_flexCounterGroupTable; std::string getRifFlexCounterTableKey(std::string s); - std::string getRifCounterTableKey(std::string s); - std::string getRifRateTableKey(std::string s); - std::string getRifRateInitTableKey(std::string s); - void cleanUpRifFromCounterDb(const string &id, const string &name); bool addRouterIntfs(sai_object_id_t vrf_id, Port &port, string loopbackAction); bool removeRouterIntfs(Port &port);