X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Ftokyotyrant.c;h=678a341c1ceeaf15f24a708d12567c1b8ed92f15;hb=fadd1df67243af6d0d4f58b10b21755ee1f433d6;hp=5260619d295d1b979057fb8c02db89ceb9c1c290;hpb=ced8c219dbf4c6b9dcfa430fb83282bfd0ccc392;p=collectd.git diff --git a/src/tokyotyrant.c b/src/tokyotyrant.c index 5260619d..678a341c 100644 --- a/src/tokyotyrant.c +++ b/src/tokyotyrant.c @@ -24,85 +24,157 @@ #include "common.h" #include "utils_cache.h" #include "utils_parse_option.h" + #include +#define DEFAULT_HOST "127.0.0.1" +#define DEFAULT_PORT 1978 + static const char *config_keys[] = { - "Host" + "Host", + "Port" }; static int config_keys_num = STATIC_ARRAY_SIZE (config_keys); -static char *host = NULL; +static char *config_host = NULL; +static char *config_port = NULL; -static int tt_config (const char *key, const char *value); -static int tt_read (void); -static void tt_submit(gauge_t rnum, const char *type); +static TCRDB *rdb = NULL; -void module_register (void) +static int tt_config (const char *key, const char *value) { - plugin_register_config("tokyotyrant", tt_config, config_keys, config_keys_num); - plugin_register_read("tokyotyrant", tt_read); + if (strcasecmp ("Host", key) == 0) + { + char *temp; + + temp = strdup (value); + if (temp == NULL) + { + ERROR("tokyotyrant plugin: Host strdup failed."); + return (1); + } + sfree (config_host); + config_host = temp; + } + else if (strcasecmp ("Port", key) == 0) + { + char *temp; + + temp = strdup (value); + if (temp == NULL) + { + ERROR("tokyotyrant plugin: Port strdup failed."); + return (1); + } + sfree (config_port); + config_port = temp; + } + else + { + ERROR ("tokyotyrant plugin: error: unrecognized configuration key %s", key); + return (-1); + } + + return (0); } -static int tt_config (const char *key, const char *value) +static void printerr() { - - if (strcasecmp ("Host", key) == 0) - { - if (host != NULL) - free (host); - host = strdup(value); - } - return (0); + int ecode = tcrdbecode(rdb); + ERROR ("tokyotyrant plugin: error: %d, %s", + ecode, tcrdberrmsg(ecode)); } -static void printerr(TCRDB *rdb) +static void tt_submit (gauge_t val, const char* type) { - int ecode = tcrdbecode(rdb); - ERROR ("tokyotyrant plugin: error: %d, %s", ecode, tcrdberrmsg(ecode)); -} + value_t values[1]; + value_list_t vl = VALUE_LIST_INIT; -static int tt_read (void) { - gauge_t rnum, size; - - TCRDB *rdb = tcrdbnew(); - - if (!tcrdbopen2(rdb, host)) - { - printerr (rdb); - tcrdbdel (rdb); - return (1); - } - - rnum = tcrdbrnum(rdb); - size = tcrdbsize(rdb); - - if (!tcrdbclose(rdb)) - { - printerr (rdb); - tcrdbdel (rdb); - return (1); - } - tt_submit (rnum, "records"); - tt_submit (size, "file_size"); - - return (0); + values[0].gauge = val; + + vl.values = values; + vl.values_len = STATIC_ARRAY_SIZE (values); + + sstrncpy (vl.host, config_host, sizeof (vl.host)); + sstrncpy (vl.plugin, "tokyotyrant", sizeof (vl.plugin)); + sstrncpy (vl.plugin_instance, config_port, + sizeof (vl.plugin_instance)); + sstrncpy (vl.type, type, sizeof (vl.type)); + + plugin_dispatch_values (&vl); } -static void tt_submit (gauge_t val, const char* type) +static void tt_open_db (void) { - value_t values[1]; - value_list_t vl = VALUE_LIST_INIT; + char* host = NULL; + int port = DEFAULT_PORT; + + if (rdb != NULL) + return; + + host = ((config_host != NULL) ? config_host : DEFAULT_HOST); + + if (config_port != NULL) + { + port = service_name_to_port_number (config_port); + if (port <= 0) + return; + } + + rdb = tcrdbnew (); + if (rdb == NULL) + return; + else if (!tcrdbopen(rdb, host, port)) + { + printerr (); + tcrdbdel (rdb); + rdb = NULL; + } +} /* void tt_open_db */ + +static int tt_read (void) { + gauge_t rnum, size; - values[0].gauge = val; + tt_open_db (); + if (rdb == NULL) + return (-1); - vl.values = values; - vl.values_len = STATIC_ARRAY_SIZE (values); + rnum = tcrdbrnum(rdb); + tt_submit (rnum, "records"); - sstrncpy (vl.host, hostname_g, sizeof (vl.host)); - sstrncpy (vl.plugin, "tokyotyrant", sizeof (vl.plugin)); - sstrncpy (vl.plugin_instance, host, sizeof (vl.plugin_instance)); - sstrncpy (vl.type, type, sizeof (vl.type)); + size = tcrdbsize(rdb); + tt_submit (size, "file_size"); - plugin_dispatch_values (&vl); + return (0); +} + +static int tt_shutdown(void) +{ + sfree(config_host); + sfree(config_port); + + if (rdb != NULL) + { + if (!tcrdbclose(rdb)) + { + printerr (); + tcrdbdel (rdb); + return (1); + } + tcrdbdel (rdb); + rdb = NULL; + } + + return(0); } + +void module_register (void) +{ + plugin_register_config("tokyotyrant", tt_config, + config_keys, config_keys_num); + plugin_register_read("tokyotyrant", tt_read); + plugin_register_shutdown("tokyotyrant", tt_shutdown); +} + +/* vim: set sw=8 ts=8 tw=78 : */