From abd8862a8190a4c9a4710f7cfe6358d656210347 Mon Sep 17 00:00:00 2001 From: Alexander Spies Date: Wed, 6 Aug 2025 17:36:14 +0200 Subject: [PATCH] Add sub-logger just for changes from rules Debugging the analyzer and optimizers is easier when we focus only on the changes they make to the query plan. Let's add a separate sub-logger to RuleExecutor so we can selectively enable only logging of those changes. --- .../xpack/esql/rule/RuleExecutor.java | 23 +++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/rule/RuleExecutor.java b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/rule/RuleExecutor.java index e4a5423d35f8e..7ee70b029031d 100644 --- a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/rule/RuleExecutor.java +++ b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/rule/RuleExecutor.java @@ -21,6 +21,25 @@ public abstract class RuleExecutor> { private final Logger log = LogManager.getLogger(getClass()); + /** + * Sub-logger intended to show only changes made by the rules. Intended for debugging. + * + * Enable it like this for the respective optimizers and the analyzer, resp. all inheritors of this class: + *
{@code
+     * PUT localhost:9200/_cluster/settings
+     *
+     * {
+     *   "transient" : {
+     *     "logger.org.elasticsearch.xpack.esql.analysis.Analyzer.changes": "TRACE",
+     *     "logger.org.elasticsearch.xpack.esql.optimizer.LogicalPlanOptimizer.changes": "TRACE",
+     *     "logger.org.elasticsearch.xpack.esql.optimizer.LocalLogicalPlanOptimizer.changes": "TRACE",
+     *     "logger.org.elasticsearch.xpack.esql.optimizer.PhysicalPlanOptimizer.changes": "TRACE",
+     *     "logger.org.elasticsearch.xpack.esql.optimizer.LocalPhysicalPlanOptimizer.changes": "TRACE"
+     *   }
+     * }
+     * }
+ */ + private final Logger changeLog = LogManager.getLogger(getClass().getName() + ".changes"); public static class Limiter { public static final Limiter DEFAULT = new Limiter(100); @@ -174,8 +193,8 @@ protected final ExecutionInfo executeWithInfo(TreeType plan) { if (tf.hasChanged()) { hasChanged = true; - if (log.isTraceEnabled()) { - log.trace("Rule {} applied with change\n{}", rule, NodeUtils.diffString(tf.before, tf.after)); + if (changeLog.isTraceEnabled()) { + changeLog.trace("Rule {} applied with change\n{}", rule, NodeUtils.diffString(tf.before, tf.after)); } } else { if (log.isTraceEnabled()) {