summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: b2b5599)
raw | patch | inline | side by side (parent: b2b5599)
author | bufadu <bufadu@gmail.com> | |
Wed, 3 May 2017 12:49:24 +0000 (14:49 +0200) | ||
committer | bufadu <bufadu@gmail.com> | |
Wed, 3 May 2017 12:49:24 +0000 (14:49 +0200) |
src/redis.c | patch | blob | history |
diff --git a/src/redis.c b/src/redis.c
index ea888ca682814fe2dc2b210edc5e629886e9a78c..4e04230b026f21e18a9d5a8c667c44839331cc2d 100644 (file)
--- a/src/redis.c
+++ b/src/redis.c
return 0;
} /* }}} int redis_handle_query */
+static int redis_db_stats(char *node, char const *info_line) /* {{{ */
+{
+ unsigned char db;
+ unsigned char max_db = 16;
+ static char field_name[10];
+ static char db_id[3];
+ char *str;
+ static char buf[MAX_REDIS_VAL_SIZE];
+ value_t val;
+ int i;
+
+ for (db = 0; db < max_db; db++) {
+ sprintf(field_name, "db%d:keys", db);
+
+ str = strstr(info_line, field_name);
+ if (str) {
+ str += strlen(field_name) + 1; /* also skip the '=' */
+ for (i = 0; (*str && (isdigit((unsigned char)*str) || *str == '.')); i++, str++)
+ buf[i] = *str;
+ buf[i] = '\0';
+
+ if (parse_value(buf, &val, DS_TYPE_GAUGE) == -1) {
+ WARNING("redis plugin: Unable to parse field `%s'.", field_name);
+ return (-1);
+ }
+
+ sprintf(db_id, "%d", db);
+ redis_submit (node, "records", db_id, val);
+ }
+ }
+ return (0);
+
+} /* }}} int redis_db_stats */
+
+
static int redis_read(void) /* {{{ */
{
for (redis_node_t *rn = nodes_head; rn != NULL; rn = rn->next) {
redis_handle_info(rn->name, rr->str, "total_bytes", "output",
"total_net_output_bytes", DS_TYPE_DERIVE);
+ redis_db_stats (rn->name, rr->str);
+
for (redis_query_t *rq = rn->queries; rq != NULL; rq = rq->next)
redis_handle_query(rh, rn, rq);