фикс: бесконечное обновление кеша из-за ошибки в логике цикла обновления
This commit is contained in:
		| @@ -15,6 +15,8 @@ | |||||||
| typedef boost::property_tree::ptree::path_type json_path; | typedef boost::property_tree::ptree::path_type json_path; | ||||||
|  |  | ||||||
| static constexpr const char* DEFAULT_QOS_CLASSES = R"({"rt1":[],"rt2":[],"rt3":[],"cd":[]})"; | static constexpr const char* DEFAULT_QOS_CLASSES = R"({"rt1":[],"rt2":[],"rt3":[],"cd":[]})"; | ||||||
|  | // пороговое значение сна | ||||||
|  | static constexpr int64_t SLEEP_THRESHOLD = 10; | ||||||
|  |  | ||||||
| // static int calculateSubnetMask(const std::string& subnet_mask) { | // static int calculateSubnetMask(const std::string& subnet_mask) { | ||||||
| //     int mask = 0; | //     int mask = 0; | ||||||
| @@ -463,7 +465,7 @@ private: | |||||||
|             bool checkNeedUpdate(int64_t now) const { |             bool checkNeedUpdate(int64_t now) const { | ||||||
|                 if (periodMs < 0) return false; |                 if (periodMs < 0) return false; | ||||||
|                 // тут нет смысла спать меньше чем на 20мс, поэтому можно разрешить чтение на некоторое время раньше |                 // тут нет смысла спать меньше чем на 20мс, поэтому можно разрешить чтение на некоторое время раньше | ||||||
|                 return now - lastUpdate >= (periodMs - 20); |                 return now - lastUpdate >= (periodMs - SLEEP_THRESHOLD); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             int64_t getNextUpdate(int64_t now) const { |             int64_t getNextUpdate(int64_t now) const { | ||||||
| @@ -543,18 +545,20 @@ private: | |||||||
|             auto now = TIME_NOW(); |             auto now = TIME_NOW(); | ||||||
|             for (auto& u: updaters) { |             for (auto& u: updaters) { | ||||||
|                 if (u.checkNeedUpdate(now)) { |                 if (u.checkNeedUpdate(now)) { | ||||||
|                     // выравнивание таймингов (-20ms...+50ms) |                     auto targetTime = u.lastUpdate + u.periodMs; | ||||||
|                     if (u.lastUpdate + u.periodMs + 50 < now) { |                     if (targetTime + SLEEP_THRESHOLD <= now && targetTime - SLEEP_THRESHOLD >= now) { | ||||||
|                         u.lastUpdate += u.periodMs; |                         u.lastUpdate = targetTime; | ||||||
|                     } else { |                     } else { | ||||||
|                         u.lastUpdate = now; |                         u.lastUpdate = now; | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     u.callback(); |                     u.callback(); | ||||||
|                     now = TIME_NOW(); |                     now = TIME_NOW(); | ||||||
|                 } |                 } | ||||||
|  |                 if (u.periodMs >= 0) { | ||||||
|                     sleepTime = std::min(sleepTime, u.getNextUpdate(now)); |                     sleepTime = std::min(sleepTime, u.getNextUpdate(now)); | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|             if (sleepTime > 0) { |             if (sleepTime > 0) { | ||||||
|                 boost::this_thread::sleep_for(boost::chrono::duration(boost::chrono::milliseconds(sleepTime))); |                 boost::this_thread::sleep_for(boost::chrono::duration(boost::chrono::milliseconds(sleepTime))); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user