[Nagiosplug-devel] Re: long names in devices whith check_disk
Orf, Tracy
orft at gknstl.com
Tue Jul 20 06:20:02 CEST 2004
I am running nagios plugins on HP-UX 11.11. As already noted, the
check_disk plugin on HP-UX doesn't work well with filesystem names
longer than about 20 characters. If anyone is interested in using the
1.3 version with HP-UX, I've attached my changes to check_disk.c that I
am using.
Replace the main while loop with this:
while (fgets (input_buffer, MAX_INPUT_BUFFER - 1,
child_process)) {
if (!index (input_buffer, '/'))
continue;
/* Fixes AIX /proc fs which lists - for size values */
if (strstr (input_buffer, "/proc ") == input_buffer)
continue;
/* Fixes HP-UX where long filesystem names cause the df
command
output to spread to two lines
*/
if (sscanf (input_buffer, "%s %f %f %f %d%% %s",
file_system,
&total_disk, &used_disk, &free_disk, &usp, mntp) ==
6 ||
sscanf (input_buffer, "%s %*s %f %f %f %d%% %s",
file_system,
&total_disk, &used_disk, &free_disk,
&usp, mntp) == 6 ||
sscanf (input_buffer, "%s %*s %f %f %f %d%% %s",
file_system,
&total_disk, &used_disk, &free_disk,
&usp, mntp) == 1) {
if (strcmp(exclude_device,file_system) == 0 ||
(strlen(mntp) > 0 &&
strcmp(exclude_device,mntp) == 0)) {
if (verbose>0)
printf ("ignoring %s.",
file_system);
continue;
}
/* filesystem info will be on the next line on
HP-UX
for long filesystem names */
if (strlen(mntp) == 0) {
if (fgets (input_buffer,
MAX_INPUT_BUFFER - 1,
child_process)) {
if (!(sscanf (input_buffer,
"%f %f %f %d%%
%s",
&total_disk,
&used_disk,
&free_disk,
&usp, mntp) == 5)) {
printf ("Unable to read
output:\n%s\n%s\n",
command_line,
input_buffer);
return result;
}
}
}
}
else {
printf ("Unable to read output:\n%s\n%s\n",
command_line, input_buffer);
return result;
}
disk_result = check_disk (usp, free_disk);
if (strcmp (file_system, "none") == 0)
strncpy (file_system, mntp, MAX_INPUT_BUFFER-1);
if (disk_result==STATE_OK && erronly && !verbose)
continue;
if (disk_result!=STATE_OK || verbose>=0)
asprintf (&output, "%s [%.0f kB (%d%%) free on
%s]", output,
free_disk, 100 - usp, display_mntp ?
mntp : file_system);
result = max_state (result, disk_result);
}
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://www.monitoring-plugins.org/archive/devel/attachments/20040720/06b9c62d/attachment.html>
More information about the Devel
mailing list