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:
Jean Flach 2018-02-21 14:59:21 +01:00
parent aea43ddeb9
commit de9adb2687
2 changed files with 38 additions and 22 deletions

View File

@ -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;
} }

View File

@ -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&);