diff options
| author | Sven Nierlein <sven@nierlein.org> | 2019-02-19 21:42:02 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-02-19 21:42:02 +0100 | 
| commit | 931ed78b5dc062fff33652d87406f1547da5ddbe (patch) | |
| tree | 9caf8031a15d7f046e77693c4002bf750bfef3d3 /plugins | |
| parent | 2813d08b92d08ba56ec22da00a23fff3a22ed74b (diff) | |
| parent | 7cafb0e84550035fe671662c293122be975065ca (diff) | |
| download | monitoring-plugins-931ed78.tar.gz | |
Merge pull request #1583 from sni/fix_check_by_ssh_timeout_child_leak
check_by_ssh: fix child process leak on timeouts
Diffstat (limited to 'plugins')
| -rw-r--r-- | plugins/check_dbi.c | 1 | ||||
| -rw-r--r-- | plugins/check_pgsql.c | 1 | ||||
| -rw-r--r-- | plugins/common.h | 14 | ||||
| -rw-r--r-- | plugins/popen.c | 29 | ||||
| -rw-r--r-- | plugins/runcmd.c | 13 | ||||
| -rw-r--r-- | plugins/utils.c | 31 | ||||
| -rw-r--r-- | plugins/utils.h | 9 | 
7 files changed, 16 insertions, 82 deletions
| diff --git a/plugins/check_dbi.c b/plugins/check_dbi.c index 826eb8d9..ced13d05 100644 --- a/plugins/check_dbi.c +++ b/plugins/check_dbi.c | |||
| @@ -35,6 +35,7 @@ const char *email = "devel@monitoring-plugins.org"; | |||
| 35 | 35 | ||
| 36 | #include "common.h" | 36 | #include "common.h" | 
| 37 | #include "utils.h" | 37 | #include "utils.h" | 
| 38 | #include "utils_cmd.h" | ||
| 38 | 39 | ||
| 39 | #include "netutils.h" | 40 | #include "netutils.h" | 
| 40 | 41 | ||
| diff --git a/plugins/check_pgsql.c b/plugins/check_pgsql.c index 5cd47093..11ce6916 100644 --- a/plugins/check_pgsql.c +++ b/plugins/check_pgsql.c | |||
| @@ -34,6 +34,7 @@ const char *email = "devel@monitoring-plugins.org"; | |||
| 34 | 34 | ||
| 35 | #include "common.h" | 35 | #include "common.h" | 
| 36 | #include "utils.h" | 36 | #include "utils.h" | 
| 37 | #include "utils_cmd.h" | ||
| 37 | 38 | ||
| 38 | #include "netutils.h" | 39 | #include "netutils.h" | 
| 39 | #include <libpq-fe.h> | 40 | #include <libpq-fe.h> | 
| diff --git a/plugins/common.h b/plugins/common.h index 6bf4fca4..0f08e2f6 100644 --- a/plugins/common.h +++ b/plugins/common.h | |||
| @@ -225,4 +225,18 @@ enum { | |||
| 225 | # define __attribute__(x) /* do nothing */ | 225 | # define __attribute__(x) /* do nothing */ | 
| 226 | #endif | 226 | #endif | 
| 227 | 227 | ||
| 228 | /* Try sysconf(_SC_OPEN_MAX) first, as it can be higher than OPEN_MAX. | ||
| 229 | * If that fails and the macro isn't defined, we fall back to an educated | ||
| 230 | * guess. There's no guarantee that our guess is adequate and the program | ||
| 231 | * will die with SIGSEGV if it isn't and the upper boundary is breached. */ | ||
| 232 | #define DEFAULT_MAXFD 256 /* fallback value if no max open files value is set */ | ||
| 233 | #define MAXFD_LIMIT 8192 /* upper limit of open files */ | ||
| 234 | #ifdef _SC_OPEN_MAX | ||
| 235 | static long maxfd = 0; | ||
| 236 | #elif defined(OPEN_MAX) | ||
| 237 | # define maxfd OPEN_MAX | ||
| 238 | #else /* sysconf macro unavailable, so guess (may be wildly inaccurate) */ | ||
| 239 | # define maxfd DEFAULT_MAXFD | ||
| 240 | #endif | ||
| 241 | |||
| 228 | #endif /* _COMMON_H_ */ | 242 | #endif /* _COMMON_H_ */ | 
| diff --git a/plugins/popen.c b/plugins/popen.c index 592263fd..116d168d 100644 --- a/plugins/popen.c +++ b/plugins/popen.c | |||
| @@ -78,7 +78,6 @@ RETSIGTYPE popen_timeout_alarm_handler (int); | |||
| 78 | 78 | ||
| 79 | #define min(a,b) ((a) < (b) ? (a) : (b)) | 79 | #define min(a,b) ((a) < (b) ? (a) : (b)) | 
| 80 | #define max(a,b) ((a) > (b) ? (a) : (b)) | 80 | #define max(a,b) ((a) > (b) ? (a) : (b)) | 
| 81 | int open_max (void); /* {Prog openmax} */ | ||
| 82 | static void err_sys (const char *, ...) __attribute__((noreturn,format(printf, 1, 2))); | 81 | static void err_sys (const char *, ...) __attribute__((noreturn,format(printf, 1, 2))); | 
| 83 | char *rtrim (char *, const char *); | 82 | char *rtrim (char *, const char *); | 
| 84 | 83 | ||
| @@ -86,7 +85,6 @@ char *pname = NULL; /* caller can set this from argv[0] */ | |||
| 86 | 85 | ||
| 87 | /*int *childerr = NULL;*//* ptr to array allocated at run-time */ | 86 | /*int *childerr = NULL;*//* ptr to array allocated at run-time */ | 
| 88 | /*extern pid_t *childpid = NULL; *//* ptr to array allocated at run-time */ | 87 | /*extern pid_t *childpid = NULL; *//* ptr to array allocated at run-time */ | 
| 89 | static int maxfd; /* from our open_max(), {Prog openmax} */ | ||
| 90 | 88 | ||
| 91 | #ifdef REDHAT_SPOPEN_ERROR | 89 | #ifdef REDHAT_SPOPEN_ERROR | 
| 92 | static volatile int childtermd = 0; | 90 | static volatile int childtermd = 0; | 
| @@ -187,13 +185,11 @@ spopen (const char *cmdstring) | |||
| 187 | argv[i] = NULL; | 185 | argv[i] = NULL; | 
| 188 | 186 | ||
| 189 | if (childpid == NULL) { /* first time through */ | 187 | if (childpid == NULL) { /* first time through */ | 
| 190 | maxfd = open_max (); /* allocate zeroed out array for child pids */ | ||
| 191 | if ((childpid = calloc ((size_t)maxfd, sizeof (pid_t))) == NULL) | 188 | if ((childpid = calloc ((size_t)maxfd, sizeof (pid_t))) == NULL) | 
| 192 | return (NULL); | 189 | return (NULL); | 
| 193 | } | 190 | } | 
| 194 | 191 | ||
| 195 | if (child_stderr_array == NULL) { /* first time through */ | 192 | if (child_stderr_array == NULL) { /* first time through */ | 
| 196 | maxfd = open_max (); /* allocate zeroed out array for child pids */ | ||
| 197 | if ((child_stderr_array = calloc ((size_t)maxfd, sizeof (int))) == NULL) | 193 | if ((child_stderr_array = calloc ((size_t)maxfd, sizeof (int))) == NULL) | 
| 198 | return (NULL); | 194 | return (NULL); | 
| 199 | } | 195 | } | 
| @@ -273,15 +269,6 @@ spclose (FILE * fp) | |||
| 273 | return (1); | 269 | return (1); | 
| 274 | } | 270 | } | 
| 275 | 271 | ||
| 276 | #ifdef OPEN_MAX | ||
| 277 | static int openmax = OPEN_MAX; | ||
| 278 | #else | ||
| 279 | static int openmax = 0; | ||
| 280 | #endif | ||
| 281 | |||
| 282 | #define OPEN_MAX_GUESS 256 /* if OPEN_MAX is indeterminate */ | ||
| 283 | /* no guarantee this is adequate */ | ||
| 284 | |||
| 285 | #ifdef REDHAT_SPOPEN_ERROR | 272 | #ifdef REDHAT_SPOPEN_ERROR | 
| 286 | RETSIGTYPE | 273 | RETSIGTYPE | 
| 287 | popen_sigchld_handler (int signo) | 274 | popen_sigchld_handler (int signo) | 
| @@ -311,22 +298,6 @@ popen_timeout_alarm_handler (int signo) | |||
| 311 | } | 298 | } | 
| 312 | 299 | ||
| 313 | 300 | ||
| 314 | int | ||
| 315 | open_max (void) | ||
| 316 | { | ||
| 317 | if (openmax == 0) { /* first time through */ | ||
| 318 | errno = 0; | ||
| 319 | if ((openmax = sysconf (_SC_OPEN_MAX)) < 0) { | ||
| 320 | if (errno == 0) | ||
| 321 | openmax = OPEN_MAX_GUESS; /* it's indeterminate */ | ||
| 322 | else | ||
| 323 | err_sys (_("sysconf error for _SC_OPEN_MAX")); | ||
| 324 | } | ||
| 325 | } | ||
| 326 | return (openmax); | ||
| 327 | } | ||
| 328 | |||
| 329 | |||
| 330 | /* Fatal error related to a system call. | 301 | /* Fatal error related to a system call. | 
| 331 | * Print a message and die. */ | 302 | * Print a message and die. */ | 
| 332 | 303 | ||
| diff --git a/plugins/runcmd.c b/plugins/runcmd.c index 1a7c904f..c3828678 100644 --- a/plugins/runcmd.c +++ b/plugins/runcmd.c | |||
| @@ -67,19 +67,6 @@ | |||
| 67 | * occur in any number of threads simultaneously. */ | 67 | * occur in any number of threads simultaneously. */ | 
| 68 | static pid_t *np_pids = NULL; | 68 | static pid_t *np_pids = NULL; | 
| 69 | 69 | ||
| 70 | /* Try sysconf(_SC_OPEN_MAX) first, as it can be higher than OPEN_MAX. | ||
| 71 | * If that fails and the macro isn't defined, we fall back to an educated | ||
| 72 | * guess. There's no guarantee that our guess is adequate and the program | ||
| 73 | * will die with SIGSEGV if it isn't and the upper boundary is breached. */ | ||
| 74 | #ifdef _SC_OPEN_MAX | ||
| 75 | static long maxfd = 0; | ||
| 76 | #elif defined(OPEN_MAX) | ||
| 77 | # define maxfd OPEN_MAX | ||
| 78 | #else /* sysconf macro unavailable, so guess (may be wildly inaccurate) */ | ||
| 79 | # define maxfd 256 | ||
| 80 | #endif | ||
| 81 | |||
| 82 | |||
| 83 | /** prototypes **/ | 70 | /** prototypes **/ | 
| 84 | static int np_runcmd_open(const char *, int *, int *) | 71 | static int np_runcmd_open(const char *, int *, int *) | 
| 85 | __attribute__((__nonnull__(1, 2, 3))); | 72 | __attribute__((__nonnull__(1, 2, 3))); | 
| diff --git a/plugins/utils.c b/plugins/utils.c index 231af92b..ee620133 100644 --- a/plugins/utils.c +++ b/plugins/utils.c | |||
| @@ -36,9 +36,6 @@ extern const char *progname; | |||
| 36 | #define STRLEN 64 | 36 | #define STRLEN 64 | 
| 37 | #define TXTBLK 128 | 37 | #define TXTBLK 128 | 
| 38 | 38 | ||
| 39 | unsigned int timeout_state = STATE_CRITICAL; | ||
| 40 | unsigned int timeout_interval = DEFAULT_SOCKET_TIMEOUT; | ||
| 41 | |||
| 42 | time_t start_time, end_time; | 39 | time_t start_time, end_time; | 
| 43 | 40 | ||
| 44 | /* ************************************************************************** | 41 | /* ************************************************************************** | 
| @@ -148,33 +145,6 @@ print_revision (const char *command_name, const char *revision) | |||
| 148 | command_name, revision, PACKAGE, VERSION); | 145 | command_name, revision, PACKAGE, VERSION); | 
| 149 | } | 146 | } | 
| 150 | 147 | ||
| 151 | const char * | ||
| 152 | state_text (int result) | ||
| 153 | { | ||
| 154 | switch (result) { | ||
| 155 | case STATE_OK: | ||
| 156 | return "OK"; | ||
| 157 | case STATE_WARNING: | ||
| 158 | return "WARNING"; | ||
| 159 | case STATE_CRITICAL: | ||
| 160 | return "CRITICAL"; | ||
| 161 | case STATE_DEPENDENT: | ||
| 162 | return "DEPENDENT"; | ||
| 163 | default: | ||
| 164 | return "UNKNOWN"; | ||
| 165 | } | ||
| 166 | } | ||
| 167 | |||
| 168 | void | ||
| 169 | timeout_alarm_handler (int signo) | ||
| 170 | { | ||
| 171 | if (signo == SIGALRM) { | ||
| 172 | printf (_("%s - Plugin timed out after %d seconds\n"), | ||
| 173 | state_text(timeout_state), timeout_interval); | ||
| 174 | exit (timeout_state); | ||
| 175 | } | ||
| 176 | } | ||
| 177 | |||
| 178 | int | 148 | int | 
| 179 | is_numeric (char *number) | 149 | is_numeric (char *number) | 
| 180 | { | 150 | { | 
| @@ -708,4 +678,3 @@ char *sperfdata_int (const char *label, | |||
| 708 | 678 | ||
| 709 | return data; | 679 | return data; | 
| 710 | } | 680 | } | 
| 711 | |||
| diff --git a/plugins/utils.h b/plugins/utils.h index a436e1ca..6aa316fe 100644 --- a/plugins/utils.h +++ b/plugins/utils.h | |||
| @@ -29,13 +29,6 @@ suite of plugins. */ | |||
| 29 | void support (void); | 29 | void support (void); | 
| 30 | void print_revision (const char *, const char *); | 30 | void print_revision (const char *, const char *); | 
| 31 | 31 | ||
| 32 | /* Handle timeouts */ | ||
| 33 | |||
| 34 | extern unsigned int timeout_state; | ||
| 35 | extern unsigned int timeout_interval; | ||
| 36 | |||
| 37 | RETSIGTYPE timeout_alarm_handler (int); | ||
| 38 | |||
| 39 | extern time_t start_time, end_time; | 32 | extern time_t start_time, end_time; | 
| 40 | 33 | ||
| 41 | /* Test input types */ | 34 | /* Test input types */ | 
| @@ -89,8 +82,6 @@ void usage4(const char *) __attribute__((noreturn)); | |||
| 89 | void usage5(void) __attribute__((noreturn)); | 82 | void usage5(void) __attribute__((noreturn)); | 
| 90 | void usage_va(const char *fmt, ...) __attribute__((noreturn)); | 83 | void usage_va(const char *fmt, ...) __attribute__((noreturn)); | 
| 91 | 84 | ||
| 92 | const char *state_text (int); | ||
| 93 | |||
| 94 | #define max(a,b) (((a)>(b))?(a):(b)) | 85 | #define max(a,b) (((a)>(b))?(a):(b)) | 
| 95 | #define min(a,b) (((a)<(b))?(a):(b)) | 86 | #define min(a,b) (((a)<(b))?(a):(b)) | 
| 96 | 87 | ||
