diff --git a/src/tokyotyrant.c b/src/tokyotyrant.c
index 5260619d295d1b979057fb8c02db89ceb9c1c290..678a341c1ceeaf15f24a708d12567c1b8ed92f15 100644 (file)
--- a/src/tokyotyrant.c
+++ b/src/tokyotyrant.c
#include "common.h"
#include "utils_cache.h"
#include "utils_parse_option.h"
+
#include <tcrdb.h>
+#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 : */