Starrocks 关于 trace 命令的说明

背景

本文基于Starrocks 3.5.5

关于trace命令的话, 有如下使用方式:

TRACE { TIMES | VALUES | LOGS | ALL } [ <module> ] <query_statement>

module的选项有:BASE, MV, OPTIMIZER, SCHEDULE, EXTERNAL

这几个模块会在ConnectProcessor.handleQueryTracers.init(ctx, parsedStmt.getTraceMode(), parsedStmt.getTraceModule())
进行初始化,也就是说如果你选择了 OPTIMIZER模块,那就是Tracers 中初始化为OPTIMIZER,所有在SeriallyTaskScheduler类中的Tracers.Module.OPTIMIZER
想关的指标信息就会记录下来,如:

OptimizerTask task = tasks.pop();
context.getOptimizerContext().setTaskContext(context);
try (Timer ignore = Tracers.watchScope(Tracers.Module.OPTIMIZER, task.getClass().getSimpleName())) {
    task.execute();
}

这些在内存中需要保留的信息只是需要跟踪的信息,而不是包括所有的module,保证了FE端内存的使用率不至于太高,从而引发OOM

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值