From 042357b51f88bb776fa8578a501e807643c8ab02 Mon Sep 17 00:00:00 2001 From: Florian Bezannier Date: Wed, 17 Jul 2024 08:38:08 +0200 Subject: [PATCH] log_to_metrics: allow custom namespace and subsystem Signed-off-by: Florian Bezannier --- build/.empty | 0 .../filter_log_to_metrics/log_to_metrics.c | 30 +++++++++++++++++-- .../filter_log_to_metrics/log_to_metrics.h | 3 ++ 3 files changed, 30 insertions(+), 3 deletions(-) delete mode 100644 build/.empty diff --git a/build/.empty b/build/.empty deleted file mode 100644 index e69de29bb2d..00000000000 diff --git a/plugins/filter_log_to_metrics/log_to_metrics.c b/plugins/filter_log_to_metrics/log_to_metrics.c index 22179577ba6..abc7389d6d1 100644 --- a/plugins/filter_log_to_metrics/log_to_metrics.c +++ b/plugins/filter_log_to_metrics/log_to_metrics.c @@ -95,6 +95,7 @@ static int log_to_metrics_destroy(struct log_to_metrics_ctx *ctx) flb_free(ctx->buckets); flb_free(ctx->bucket_counter); flb_free(ctx->label_counter); + flb_sds_destroy(ctx->metric_subsystem); flb_free(ctx); return 0; } @@ -453,6 +454,8 @@ static int cb_log_to_metrics_init(struct flb_filter_instance *f_ins, flb_sds_t tmp; char metric_description[MAX_METRIC_LENGTH]; char metric_name[MAX_METRIC_LENGTH]; + char metric_namespace[MAX_METRIC_LENGTH]; + char metric_subsystem[MAX_METRIC_LENGTH]; char value_field[MAX_METRIC_LENGTH]; struct flb_input_instance *input_ins; int label_count; @@ -556,6 +559,14 @@ static int cb_log_to_metrics_init(struct flb_filter_instance *f_ins, return -1; } snprintf(metric_name, sizeof(metric_name) - 1, "%s", ctx->metric_name); + snprintf(metric_namespace, sizeof(metric_namespace) - 1, "%s", ctx->metric_namespace); + + /* Check property subsystem name */ + if (ctx->metric_subsystem == NULL || strlen(ctx->metric_subsystem) == 0) { + ctx->metric_subsystem = flb_sds_create(tmp); + } + snprintf(metric_subsystem, sizeof(metric_subsystem) - 1, "%s", + ctx->metric_subsystem); /* Check property metric description */ if (ctx->metric_description == NULL || @@ -602,17 +613,17 @@ static int cb_log_to_metrics_init(struct flb_filter_instance *f_ins, /* Depending on mode create different types of cmetrics metrics */ switch (ctx->mode) { case FLB_LOG_TO_METRICS_COUNTER: - ctx->c = cmt_counter_create(ctx->cmt, "log_metric", "counter", + ctx->c = cmt_counter_create(ctx->cmt, metric_namespace, metric_subsystem, metric_name, metric_description, label_count, ctx->label_keys); break; case FLB_LOG_TO_METRICS_GAUGE: - ctx->g = cmt_gauge_create(ctx->cmt, "log_metric", "gauge", + ctx->g = cmt_gauge_create(ctx->cmt, metric_namespace, metric_subsystem, metric_name, metric_description, label_count, ctx->label_keys); break; case FLB_LOG_TO_METRICS_HISTOGRAM: - ctx->h = cmt_histogram_create(ctx->cmt, "log_metric", "histogram", + ctx->h = cmt_histogram_create(ctx->cmt, metric_namespace, metric_subsystem, metric_name, metric_description, ctx->histogram_buckets, label_count, ctx->label_keys); @@ -956,6 +967,19 @@ static struct flb_config_map config_map[] = { offsetof(struct log_to_metrics_ctx, metric_name), "Name of metric" }, + { + FLB_CONFIG_MAP_STR, "metric_namespace", + DEFAULT_LOG_TO_METRICS_NAMESPACE, + FLB_FALSE, FLB_TRUE, + offsetof(struct log_to_metrics_ctx, metric_namespace), + "Namespace of the metric" + }, + { + FLB_CONFIG_MAP_STR, "metric_subsystem",NULL, + FLB_FALSE, FLB_TRUE, + offsetof(struct log_to_metrics_ctx, metric_subsystem), + "Subsystem of the metric" + }, { FLB_CONFIG_MAP_STR, "metric_description", NULL, FLB_FALSE, FLB_TRUE, diff --git a/plugins/filter_log_to_metrics/log_to_metrics.h b/plugins/filter_log_to_metrics/log_to_metrics.h index c5f8706440c..4f1414d0b11 100644 --- a/plugins/filter_log_to_metrics/log_to_metrics.h +++ b/plugins/filter_log_to_metrics/log_to_metrics.h @@ -49,6 +49,7 @@ #define MAX_LABEL_COUNT 32 #define FLB_MEM_BUF_LIMIT_DEFAULT "10M" +#define DEFAULT_LOG_TO_METRICS_NAMESPACE "log_metric" struct log_to_metrics_ctx @@ -57,6 +58,8 @@ struct log_to_metrics_ctx struct flb_filter_instance *ins; int mode; flb_sds_t metric_name; + flb_sds_t metric_namespace; + flb_sds_t metric_subsystem; flb_sds_t metric_description; struct cmt *cmt; struct flb_input_instance *input_ins;