in src/oomd/plugins/PressureAbove.cpp [55:114]
Engine::PluginRet PressureAbove::run(OomdContext& ctx) {
using std::chrono::steady_clock;
ResourcePressure current_pressure;
int64_t current_memory_usage = 0;
for (const CgroupContext& cgroup_ctx : ctx.addToCacheAndGet(cgroups_)) {
ResourcePressure rp;
switch (resource_) {
case ResourceType::IO:
rp = cgroup_ctx.io_pressure().value_or(rp);
break;
case ResourceType::MEMORY:
rp = cgroup_ctx.mem_pressure().value_or(rp);
break;
// No default to catch new additions in ResourceType
}
// Do a weighted comparison (we care more about 10s, then 60s, then 300s)
if (rp.sec_10 * 3 + rp.sec_60 * 2 + rp.sec_300 >
current_pressure.sec_10 * 3 + current_pressure.sec_60 * 2 +
current_pressure.sec_300) {
current_pressure = rp;
current_memory_usage = cgroup_ctx.current_usage().value_or(0);
}
}
OOMD_SCOPE_EXIT {
last_pressure_ = current_pressure;
};
const auto now = steady_clock::now();
// Check if the 10s pressure is above threshold_ for duration_
if (current_pressure.sec_10 > threshold_) {
if (hit_thres_at_ == steady_clock::time_point()) {
hit_thres_at_ = now;
}
const auto diff =
std::chrono::duration_cast<std::chrono::seconds>(now - hit_thres_at_)
.count();
if (diff >= duration_) {
std::ostringstream oss;
oss << std::setprecision(2) << std::fixed;
oss << "10s pressure " << current_pressure.sec_10
<< " is over the threshold of " << threshold_ << " for " << duration_
<< " seconds , total usage is " << current_memory_usage / 1024 / 1024
<< "MB";
OLOG << oss.str();
return Engine::PluginRet::CONTINUE;
}
} else {
hit_thres_at_ = steady_clock::time_point();
}
return Engine::PluginRet::STOP;
}