2 * collectd - src/ping.c
3 * Copyright (C) 2005 Florian octo Forster
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20 * Florian octo Forster <octo at verplant.org>
26 #define MODULE_NAME "ping"
31 #include <netinet/in.h>
32 #include "libping/ping.h"
34 extern char *pinghosts[MAX_PINGHOSTS];
35 extern int num_pinghosts;
36 static int hosts_flags[MAX_PINGHOSTS];
37 static int hosts_disable[MAX_PINGHOSTS];
38 static int hosts_backoff[MAX_PINGHOSTS];
40 static char *file_template = "ping-%s.rrd";
42 static char *ds_def[] =
44 "DS:ping:GAUGE:25:0:65535",
47 static int ds_num = 1;
53 for (i = 0; i < MAX_PINGHOSTS; i++)
63 void ping_write (char *host, char *inst, char *val)
68 status = snprintf (file, 512, file_template, inst);
71 else if (status >= 512)
74 rrd_update_file (host, file, val, ds_def, ds_num);
78 void ping_submit (int ping_time, char *host)
82 if (snprintf (buf, BUFSIZE, "%u:%u", (unsigned int) curtime, ping_time) >= BUFSIZE)
85 plugin_submit (MODULE_NAME, host, buf);
94 for (i = 0; i < num_pinghosts; i++)
96 if (hosts_disable[i] > 0)
102 ping = tpinghost (pinghosts[i]);
107 if (!(hosts_flags[i] & 0x01))
108 syslog (LOG_WARNING, "ping %s: Connection timed out.", pinghosts[i]);
109 hosts_flags[i] |= 0x01;
113 if (!(hosts_flags[i] & 0x02))
114 syslog (LOG_WARNING, "ping %s: Host or service is not reachable.", pinghosts[i]);
115 hosts_flags[i] |= 0x02;
119 syslog (LOG_ERR, "ping %s: Socket error. Ping will be disabled for %i iteration(s).",
120 pinghosts[i], hosts_backoff[i]);
121 hosts_disable[i] = hosts_backoff[i];
122 if (hosts_backoff[i] < 8192) /* 22 3/4 hours */
123 hosts_backoff[i] *= 2;
124 hosts_flags[i] |= 0x10;
128 if (!(hosts_flags[i] & 0x04))
129 syslog (LOG_WARNING, "ping %s: Connection refused.", pinghosts[i]);
130 hosts_flags[i] |= 0x04;
134 if (hosts_flags[i] != 0x00)
135 syslog (LOG_NOTICE, "ping %s: Back to normal: %ims.", pinghosts[i], ping);
136 hosts_flags[i] = 0x00;
137 hosts_backoff[i] = 1;
138 ping_submit (ping, pinghosts[i]);
139 } /* switch (ping) */
140 } /* for (i = 0; i < num_pinghosts; i++) */
143 void module_register (void)
145 plugin_register (MODULE_NAME, ping_init, ping_read, ping_write);
149 #endif /* COLLECT_PING */