diff options
author | Ton Voon <tonvoon@users.sourceforge.net> | 2006-08-11 08:26:34 (GMT) |
---|---|---|
committer | Ton Voon <tonvoon@users.sourceforge.net> | 2006-08-11 08:26:34 (GMT) |
commit | 0c2be6a608135d8a45c82a1c0ada5e8020bc2409 (patch) | |
tree | cc1c96e681de1de347a0e34eadf571d18c39de48 /plugins/check_ntp.c | |
parent | 4c50478efce19e079c030574e1b23bf02a50573a (diff) | |
download | monitoring-plugins-0c2be6a608135d8a45c82a1c0ada5e8020bc2409.tar.gz |
Catch no responses from any server (1538341 - nmdias)
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1467 f882894a-f735-0410-b71e-b25c423dba1c
Diffstat (limited to 'plugins/check_ntp.c')
-rw-r--r-- | plugins/check_ntp.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/plugins/check_ntp.c b/plugins/check_ntp.c index 9cda277..f9dc49a 100644 --- a/plugins/check_ntp.c +++ b/plugins/check_ntp.c | |||
@@ -335,7 +335,7 @@ int best_offset_server(const ntp_server_results *slist, int nservers){ | |||
335 | * we have to do it in a way that our lazy macros don't handle currently :( */ | 335 | * we have to do it in a way that our lazy macros don't handle currently :( */ |
336 | double offset_request(const char *host, int *status){ | 336 | double offset_request(const char *host, int *status){ |
337 | int i=0, j=0, ga_result=0, num_hosts=0, *socklist=NULL, respnum=0; | 337 | int i=0, j=0, ga_result=0, num_hosts=0, *socklist=NULL, respnum=0; |
338 | int servers_completed=0, one_written=0, servers_readable=0, best_index=-1; | 338 | int servers_completed=0, one_written=0, one_read=0, servers_readable=0, best_index=-1; |
339 | time_t now_time=0, start_ts=0; | 339 | time_t now_time=0, start_ts=0; |
340 | ntp_message *req=NULL; | 340 | ntp_message *req=NULL; |
341 | double avg_offset=0.; | 341 | double avg_offset=0.; |
@@ -437,12 +437,17 @@ double offset_request(const char *host, int *status){ | |||
437 | servers[i].rtdelay=NTP32asDOUBLE(req[i].rtdelay); | 437 | servers[i].rtdelay=NTP32asDOUBLE(req[i].rtdelay); |
438 | servers[i].waiting=0; | 438 | servers[i].waiting=0; |
439 | servers_readable--; | 439 | servers_readable--; |
440 | one_read = 1; | ||
440 | if(servers[i].num_responses==AVG_NUM) servers_completed++; | 441 | if(servers[i].num_responses==AVG_NUM) servers_completed++; |
441 | } | 442 | } |
442 | } | 443 | } |
443 | /* lather, rinse, repeat. */ | 444 | /* lather, rinse, repeat. */ |
444 | } | 445 | } |
445 | 446 | ||
447 | if (one_read == 0) { | ||
448 | die(STATE_CRITICAL, "NTP CRITICAL: No response from NTP server\n"); | ||
449 | } | ||
450 | |||
446 | /* now, pick the best server from the list */ | 451 | /* now, pick the best server from the list */ |
447 | best_index=best_offset_server(servers, num_hosts); | 452 | best_index=best_offset_server(servers, num_hosts); |
448 | if(best_index < 0){ | 453 | if(best_index < 0){ |