diff --git a/pkg/ruler/evaluator_local.go b/pkg/ruler/evaluator_local.go index 00faabd7ea499..63a3026f54565 100644 --- a/pkg/ruler/evaluator_local.go +++ b/pkg/ruler/evaluator_local.go @@ -3,9 +3,11 @@ package ruler import ( "context" "fmt" + "github.com/go-kit/log/level" "time" "github.com/go-kit/log" + "github.com/grafana/loki/v3/pkg/util" "github.com/grafana/loki/v3/pkg/logproto" "github.com/grafana/loki/v3/pkg/logql" @@ -49,5 +51,9 @@ func (l *LocalEvaluator) Eval(ctx context.Context, qs string, now time.Time) (*l return nil, err } + // Retrieve rule details from context + ruleName, ruleType := GetRuleDetailsFromContext(ctx) + + level.Info(l.logger).Log("msg", "request timings", "insight", "true", "source", "loki_ruler", "rule_name", ruleName, "rule_type", ruleType, "total", res.Statistics.Summary.ExecTime, "total_bytes", res.Statistics.Summary.TotalBytesProcessed, "query_hash", util.HashedQuery(qs)) return &res, nil } diff --git a/pkg/ruler/evaluator_remote.go b/pkg/ruler/evaluator_remote.go index c5db5801f6e41..694b26efe3dac 100644 --- a/pkg/ruler/evaluator_remote.go +++ b/pkg/ruler/evaluator_remote.go @@ -281,7 +281,9 @@ func (r *RemoteEvaluator) query(ctx context.Context, orgID, query string, ts tim level.Debug(log).Log("msg", "rule evaluation succeeded") r.metrics.successfulEvals.WithLabelValues(orgID).Inc() - return r.decodeResponse(ctx, resp, orgID) + dr, err := r.decodeResponse(ctx, resp, orgID) + level.Info(log).Log("msg", "request timings", "insight", "true", "source", "loki_ruler", "rule_name", ruleName, "rule_type", ruleType, "total", dr.Statistics.Summary.ExecTime, "total_bytes", dr.Statistics.Summary.TotalBytesProcessed, "query_hash", util.HashedQuery(query)) + return dr, err } func (r *RemoteEvaluator) decodeResponse(ctx context.Context, resp *httpgrpc.HTTPResponse, orgID string) (*logqlmodel.Result, error) {