From 2919b2516310e0ebc99959143cf0a0927e6f3350 Mon Sep 17 00:00:00 2001 From: zhya Date: Thu, 28 Nov 2024 13:36:48 +0800 Subject: [PATCH] chore(storage): do compact before recluster during compact hook (#16949) * chore: do compact before recluster during compact hook * update --------- Co-authored-by: dantengsky --- .../src/interpreters/hook/compact_hook.rs | 39 ++++++++++--------- 1 file changed, 20 insertions(+), 19 deletions(-) diff --git a/src/query/service/src/interpreters/hook/compact_hook.rs b/src/query/service/src/interpreters/hook/compact_hook.rs index 48b416c929fa..8f2962621421 100644 --- a/src/query/service/src/interpreters/hook/compact_hook.rs +++ b/src/query/service/src/interpreters/hook/compact_hook.rs @@ -147,9 +147,6 @@ async fn compact_table( .await?; let settings = ctx.get_settings(); - let do_recluster = !table.cluster_keys(ctx.clone()).is_empty(); - let do_compact = compaction_limits.block_limit.is_some() || !do_recluster; - // evict the table from cache ctx.evict_table_from_cache( &compact_target.catalog, @@ -157,7 +154,8 @@ async fn compact_table( &compact_target.table, )?; - if do_compact { + { + // do compact. let compact_block = RelOperator::CompactBlock(OptimizeCompactBlock { catalog: compact_target.catalog.clone(), database: compact_target.database.clone(), @@ -191,21 +189,24 @@ async fn compact_table( } } - if do_recluster { - let recluster = RelOperator::Recluster(Recluster { - catalog: compact_target.catalog, - database: compact_target.database, - table: compact_target.table, - filters: None, - limit: Some(settings.get_auto_compaction_segments_limit()? as usize), - }); - let s_expr = SExpr::create_leaf(Arc::new(recluster)); - let recluster_interpreter = - ReclusterTableInterpreter::try_create(ctx.clone(), s_expr, lock_opt, false)?; - // Recluster will be done in `ReclusterTableInterpreter::execute2` directly, - // we do not need to use `PipelineCompleteExecutor` to execute it. - let build_res = recluster_interpreter.execute2().await?; - assert!(build_res.main_pipeline.is_empty()); + { + // do recluster. + if !table.cluster_keys(ctx.clone()).is_empty() { + let recluster = RelOperator::Recluster(Recluster { + catalog: compact_target.catalog, + database: compact_target.database, + table: compact_target.table, + filters: None, + limit: Some(settings.get_auto_compaction_segments_limit()? as usize), + }); + let s_expr = SExpr::create_leaf(Arc::new(recluster)); + let recluster_interpreter = + ReclusterTableInterpreter::try_create(ctx.clone(), s_expr, lock_opt, false)?; + // Recluster will be done in `ReclusterTableInterpreter::execute2` directly, + // we do not need to use `PipelineCompleteExecutor` to execute it. + let build_res = recluster_interpreter.execute2().await?; + assert!(build_res.main_pipeline.is_empty()); + } } Ok(())