X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fceph.c;h=3accbd3f80d20a8d9b3c5c8e28af961c2d613aa9;hb=8fd8f76dc11064e75e44448d16d35e09e46191a2;hp=0b064de3fe12fd193383344e27732cea7e75aa91;hpb=9bb21a2b154cb12e3c96280dac9cdabf969c4b79;p=collectd.git diff --git a/src/ceph.c b/src/ceph.c index 0b064de3..3accbd3f 100644 --- a/src/ceph.c +++ b/src/ceph.c @@ -396,7 +396,7 @@ static void ceph_daemon_free(struct ceph_daemon *d) { } /* compact_ds_name removed the special characters ":", "_", "-" and "+" from the - * intput string. Characters following these special characters are capitalized. + * input string. Characters following these special characters are capitalized. * Trailing "+" and "-" characters are replaces with the strings "Plus" and * "Minus". */ static int compact_ds_name(char *buffer, size_t buffer_size, char const *src) { @@ -486,7 +486,7 @@ static _Bool has_suffix(char const *str, char const *suffix) { } static void cut_suffix(char *buffer, size_t buffer_size, char const *str, - char const *suffix) { + char const *suffix) { size_t str_len = strlen(str); size_t suffix_len = strlen(suffix); @@ -516,25 +516,22 @@ static size_t count_parts(char const *key) { static int parse_keys(char *buffer, size_t buffer_size, const char *key_str) { char tmp[2 * buffer_size]; size_t tmp_size = sizeof(tmp); + const char *cut_suffixes[] = {".type", ".avgcount", ".sum", ".avgtime"}; if (buffer == NULL || buffer_size == 0 || key_str == NULL || strlen(key_str) == 0) return EINVAL; + + sstrncpy(tmp, key_str, tmp_size); + /* Strip suffix if it is ".type" or one of latency metric suffix. */ if (count_parts(key_str) > 2) { - if (has_suffix(key_str, ".type")) { - cut_suffix(tmp, tmp_size, key_str, ".type"); - } else if (has_suffix(key_str, ".avgcount")) { - cut_suffix(tmp, tmp_size, key_str, ".avgcount"); - } else if (has_suffix(key_str, ".sum")) { - cut_suffix(tmp, tmp_size, key_str, ".sum"); - } else if (has_suffix(key_str, ".avgtime")) { - cut_suffix(tmp, tmp_size, key_str, ".avgtime"); - } else { - sstrncpy(tmp, key_str, sizeof(tmp)); + for (size_t i = 0; i < STATIC_ARRAY_SIZE(cut_suffixes); i++) { + if (has_suffix(key_str, cut_suffixes[i])) { + cut_suffix(tmp, tmp_size, key_str, cut_suffixes[i]); + break; + } } - } else { - sstrncpy(tmp, key_str, sizeof(tmp)); } return compact_ds_name(buffer, buffer_size, tmp); @@ -930,7 +927,13 @@ static int node_handler_fetch_data(void *arg, const char *val, uv.gauge = result; vtmp->latency_index = (vtmp->latency_index + 1); } else if (has_suffix(key, ".avgtime")) { - // skip this step if no need in long run latency + + /* The "avgtime" metric reports ("sum" / "avgcount"), i.e. the average + * time per request since the start of the Ceph daemon. Report this only + * when the user has configured "long running average". Otherwise, use the + * rate of "sum" and "avgcount" to calculate the current latency. + */ + if (!long_run_latency_avg) { return 0; }