VastbaseG100

基于openGauss内核开发的企业级关系型数据库。

Menu

SQL自诊断

用户在执行查询或者执行INSERT/DELETE/UPDATE/CREATE TABLE AS语句时,可能会遇到性能问题。这种情况下,通过查询GS_WLM_SESSION_STATISTICSGS_WLM_SESSION_HISTORY视图的warning字段可以获得对应查询可能导致性能问题的告警信息,为性能调优提供参考。

SQL自诊断的告警类型与resource_track_level的设置有关系。如果resource_track_level设置为query,则可以诊断多列/单列统计信息未收集和SQL不下推的告警。如果resource_track_level设置为operator,则可以诊断所有的告警场景。

SQL自诊断的诊断范围与resource_track_cost的设置有关系。当SQL的代价大于resource_track_cost时,SQL才会被诊断。SQL的代价可以通过explain来确认。

告警场景

目前支持对多列/单列统计信息未收集导致性能问题的场景上报告警。

如果存在单列或者多列统计信息未收集,则上报相关告警。调优方法可以参考更新统计信息统计信息调优

告警信息示例:

  • 整表的统计信息未收集:

    Statistic Not Collect:
    schema_name.table_name1
    
  • 单列统计信息未收集:

    Statistic Not Collect:
    schema_name.table_name2(c1,c2)
    
  • 多列统计信息未收集:

    Statistic Not Collect:
    schema_name.table_name3((c1,c2))
    
  • 单列和多列统计信息未收集:

    Statistic Not Collect:
    schema_name.table_name4(c1,c2)    schema_name.table_name4((c1,c2))
    

规格约束

1、告警字符串长度上限为2048。如果告警信息超过这个长度(例如存在大量未收集统计信息的超长表名、列名等信息)则不告警,只上报warning:

WARNING, "Planner issue report is truncated, the rest of planner issues will be skipped"

2、如果query存在limit节点(即查询语句中包含limit),则不会上报limit节点以下的Operator级别的告警。