summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 87d1ec4)
raw | patch | inline | side by side (parent: 87d1ec4)
author | Ton Voon <tonvoon@users.sourceforge.net> | |
Thu, 11 Mar 2004 15:17:08 +0000 (15:17 +0000) | ||
committer | Ton Voon <tonvoon@users.sourceforge.net> | |
Thu, 11 Mar 2004 15:17:08 +0000 (15:17 +0000) |
be moved into utils.c in future
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@845 f882894a-f735-0410-b71e-b25c423dba1c
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@845 f882894a-f735-0410-b71e-b25c423dba1c
plugins/check_nagios.c | patch | blob | history |
diff --git a/plugins/check_nagios.c b/plugins/check_nagios.c
index 27bb0103d3fcf446ea950e5bf873c9981c813863..d9d18d9b5182c2c9e7c5be7ab8c1ec23433382de 100644 (file)
--- a/plugins/check_nagios.c
+++ b/plugins/check_nagios.c
char procprog[MAX_INPUT_BUFFER];
char *procargs;
int pos, cols;
+ int expected_cols = PS_COLS - 1;
+ const char *zombie = "Z";
+ char *temp_string;
setlocale (LC_ALL, "");
bindtextdomain (PACKAGE, LOCALEDIR);
}
fclose (fp);
+ if (verbose >= 2)
+ printf("command: %s\n", PS_COMMAND);
+
/* run the command to check for the Nagios process.. */
child_process = spopen (PS_COMMAND);
if (child_process == NULL) {
/* count the number of matching Nagios processes... */
while (fgets (input_buffer, MAX_INPUT_BUFFER - 1, child_process)) {
cols = sscanf (input_buffer, PS_FORMAT, PS_VARLIST);
- if ( cols >= 6 ) {
+ /* Zombie processes do not give a procprog command */
+ if ( cols == (expected_cols - 1) && strstr(procstat, zombie) ) {
+ cols = expected_cols;
+ /* Set some value for procargs for the strip command further below
+ Seen to be a problem on some Solaris 7 and 8 systems */
+ input_buffer[pos] = '\n';
+ input_buffer[pos+1] = 0x0;
+ }
+ if ( cols >= expected_cols ) {
asprintf (&procargs, "%s", input_buffer + pos);
strip (procargs);
- if (!strstr(procargs, argv[0]) && strstr(procargs, process_string)) {
+ /* Some ps return full pathname for command. This removes path */
+ temp_string = strtok ((char *)procprog, "/");
+ while (temp_string) {
+ strcpy(procprog, temp_string);
+ temp_string = strtok (NULL, "/");
+ }
+
+ /* May get empty procargs */
+ if (!strstr(procargs, argv[0]) && strstr(procprog, process_string) && strcmp(procargs,"")) {
proc_entries++;
- if (verbose)
- printf (_("Found process: %s\n"), procargs);
+ if (verbose >= 2) {
+ printf (_("Found process: %s %s\n"), procprog, procargs);
+ }
}
}
}