慢查询分析

最近更新时间: 2025-01-15 17:01:00

功能说明

超过指定时间的 SQL 语句查询称为“慢查询”,对应语句称为“慢查询语句”,而数据库管理员(DBA)对慢查询语句进行分析并找到慢查询出现原因的过程叫做慢查询分析。

云数据库 MySQL/MariaDB 在实例管理页的【性能优化】模块下,提供慢查询分析能力。

主要参数说明

主要默认设置

  • 慢查询功能:默认开启
  • 慢查询时间(long_query_time):默认配置为1s;即慢查询语句查询时间超过1s的才被记录。
  • 分析数据输出延迟:1分钟 - 5分钟。
  • 日志记录时长:30天,根据备份和日志设置周期决定。

分析列表字段说明

  • 校验值(checksum):标示慢查询语句的一串序列数字,默认64bit。
  • 抽象后的慢查询语句(fingerprint):隐去用户数据以后的慢查询语句。
  • 数据库:出现慢查询语句的数据库。
  • 账号:出现慢查询语句的账号。
  • 最后执行时间(last_seen):时间范围内,最后一次出现慢查询语句的时间。
  • 首次执行时间(first_seen):时间范围内,第一次出现慢查询语句的时间。
  • 总次数(ts_cnt):时间范围内,慢查询语句出现的次数。
  • 总次数占比:时间范围内,慢查询语句占所有慢查询语句次数的占比。
  • 总时间(query_time_sum):时间范围内,慢查询语句查询总耗时。
  • 总时间占比:时间范围内,慢查询语句查询总耗时的占比。
  • 平均时间(query_time_avg):慢查询语句总时间除以总次数的平均时间。
  • 最小时间(query_time_min):慢查询语句出现的最小时间。
  • 最大时间(query_time_max):慢查询语句出现的最大时间。
  • 总锁时间(lock_time_sum):慢查询语句出现锁的总耗时。
  • 总锁时间占比:时间范围内,慢查询语句占所有慢查询语句锁时间的占比。
  • 平均锁时间(lock_time_avg):慢查询语句总锁时间除以总锁次数的平均时间。
  • 最小锁时间(lock_time_min):慢查询语句锁出现的最小时间。
  • 最大锁时间(lock_time_max):慢查询语句锁出现的最大时间。
  • 发送行数(Rows_sent_sum):该条慢查询语句发送的数据行数总和。
  • 扫描行数(Rows_examined_sum):该条慢查询语句扫描的数据行数总和。