mirror of https://github.com/Icinga/icinga2.git
Add 'used' feature to check_memory
Analogous to check_disk -U can now be used to check against and print the used memory instead of the default available memory. fixes #6108
This commit is contained in:
parent
aea43ddeb9
commit
de9adb2687
|
@ -59,6 +59,7 @@ INT parseArguments(INT ac, WCHAR ** av, po::variables_map& vm, printInfoStruct&
|
||||||
("warning,w", po::wvalue<std::wstring>(), "Warning threshold")
|
("warning,w", po::wvalue<std::wstring>(), "Warning threshold")
|
||||||
("critical,c", po::wvalue<std::wstring>(), "Critical threshold")
|
("critical,c", po::wvalue<std::wstring>(), "Critical threshold")
|
||||||
("unit,u", po::wvalue<std::wstring>(), "The unit to use for display (default MB)")
|
("unit,u", po::wvalue<std::wstring>(), "The unit to use for display (default MB)")
|
||||||
|
("show-used,U", "Show used memory instead of the free memory")
|
||||||
;
|
;
|
||||||
|
|
||||||
po::basic_command_line_parser<WCHAR> parser(ac, av);
|
po::basic_command_line_parser<WCHAR> parser(ac, av);
|
||||||
|
@ -154,6 +155,8 @@ INT parseArguments(INT ac, WCHAR ** av, po::variables_map& vm, printInfoStruct&
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
printInfo.showUsed = vm.count("show-used") > 0;
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,31 +165,43 @@ INT printOutput(printInfoStruct& printInfo)
|
||||||
if (debug)
|
if (debug)
|
||||||
std::wcout << L"Constructing output string" << '\n';
|
std::wcout << L"Constructing output string" << '\n';
|
||||||
|
|
||||||
state state = OK;
|
state state;
|
||||||
|
std::wstringstream output;
|
||||||
|
|
||||||
if (printInfo.warn.rend(printInfo.aRam, printInfo.tRam))
|
if (!printInfo.showUsed) {
|
||||||
state = WARNING;
|
if (printInfo.warn.rend(printInfo.aRam, printInfo.tRam)) {
|
||||||
|
state = WARNING;
|
||||||
if (printInfo.crit.rend(printInfo.aRam, printInfo.tRam))
|
output << L"MEMORY WARNING - ";
|
||||||
state = CRITICAL;
|
} else if (printInfo.crit.rend(printInfo.aRam, printInfo.tRam)) {
|
||||||
|
state = CRITICAL;
|
||||||
switch (state) {
|
output << L"MEMORY CRITICAL - ";
|
||||||
case OK:
|
} else {
|
||||||
std::wcout << L"MEMORY OK - " << printInfo.percentFree << L"% free | memory=" << printInfo.aRam << BunitStr(printInfo.unit) << L";"
|
state = OK;
|
||||||
|
output << L"MEMORY OK - ";
|
||||||
|
}
|
||||||
|
output << printInfo.percentFree << L"% free | memory = " << printInfo.aRam << BunitStr(printInfo.unit) << L";"
|
||||||
<< printInfo.warn.pString(printInfo.tRam) << L";" << printInfo.crit.pString(printInfo.tRam)
|
<< printInfo.warn.pString(printInfo.tRam) << L";" << printInfo.crit.pString(printInfo.tRam)
|
||||||
<< L";0;" << printInfo.tRam << '\n';
|
<< L";0;" << printInfo.tRam;
|
||||||
break;
|
|
||||||
case WARNING:
|
|
||||||
std::wcout << L"MEMORY WARNING - " << printInfo.percentFree << L"% free | memory=" << printInfo.aRam << BunitStr(printInfo.unit) << L";"
|
|
||||||
<< printInfo.warn.pString(printInfo.tRam) << L";" << printInfo.crit.pString(printInfo.tRam)
|
|
||||||
<< L";0;" << printInfo.tRam << '\n';
|
|
||||||
break;
|
|
||||||
case CRITICAL:
|
|
||||||
std::wcout << L"MEMORY CRITICAL - " << printInfo.percentFree << L"% free | memory=" << printInfo.aRam << BunitStr(printInfo.unit) << L";"
|
|
||||||
<< printInfo.warn.pString(printInfo.tRam) << L";" << printInfo.crit.pString(printInfo.tRam)
|
|
||||||
<< L";0;" << printInfo.tRam << '\n';
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
if (printInfo.warn.rend(printInfo.tRam - printInfo.aRam, printInfo.tRam)) {
|
||||||
|
state = WARNING;
|
||||||
|
output << L"MEMORY WARNING - ";
|
||||||
|
}
|
||||||
|
else if (printInfo.crit.rend(printInfo.tRam - printInfo.aRam, printInfo.tRam)) {
|
||||||
|
state = CRITICAL;
|
||||||
|
output << L"MEMORY CRITICAL - ";
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
state = OK;
|
||||||
|
output << L"MEMORY OK - ";
|
||||||
|
}
|
||||||
|
output << 100 - printInfo.percentFree << L"% used | memory = " << printInfo.tRam - printInfo.aRam << BunitStr(printInfo.unit) << L";"
|
||||||
|
<< printInfo.warn.pString(printInfo.tRam) << L";" << printInfo.crit.pString(printInfo.tRam)
|
||||||
|
<< L";0;" << printInfo.tRam;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::wcout << output.str() << std::endl;
|
||||||
|
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,6 +29,7 @@ struct printInfoStruct
|
||||||
DOUBLE tRam, aRam;
|
DOUBLE tRam, aRam;
|
||||||
DOUBLE percentFree;
|
DOUBLE percentFree;
|
||||||
Bunit unit = BunitMB;
|
Bunit unit = BunitMB;
|
||||||
|
BOOL showUsed;
|
||||||
};
|
};
|
||||||
|
|
||||||
INT parseArguments(INT, WCHAR **, boost::program_options::variables_map&, printInfoStruct&);
|
INT parseArguments(INT, WCHAR **, boost::program_options::variables_map&, printInfoStruct&);
|
||||||
|
|
Loading…
Reference in New Issue