Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

infoschema, util: add table events_statements_summary_by_digest_history #13813

Merged
merged 11 commits into from
Dec 9, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 18 additions & 2 deletions config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -416,10 +416,16 @@ type PessimisticTxn struct {

// StmtSummary is the config for statement summary.
type StmtSummary struct {
// Enable statement summary or not.
Enable bool `toml:"enable" json:"enable"`
// The maximum number of statements kept in memory.
MaxStmtCount uint `toml:"max-stmt-count" json:"max-stmt-count"`
// The maximum length of displayed normalized SQL and sample SQL.
MaxSQLLength uint `toml:"max-sql-length" json:"max-sql-length"`
// The refresh interval of statement summary.
RefreshInterval int `toml:"refresh-interval" json:"refresh-interval"`
// The maximum history size of statement summary.
HistorySize int `toml:"history-size" json:"history-size"`
}

var defaultConf = Config{
Expand Down Expand Up @@ -529,8 +535,11 @@ var defaultConf = Config{
MaxRetryCount: 256,
},
StmtSummary: StmtSummary{
MaxStmtCount: 100,
MaxSQLLength: 4096,
Enable: false,
MaxStmtCount: 100,
MaxSQLLength: 4096,
RefreshInterval: 1800,
HistorySize: 24,
},
}

Expand Down Expand Up @@ -714,6 +723,13 @@ func (c *Config) Valid() error {
if c.Performance.TxnTotalSizeLimit > (10 << 30) {
return fmt.Errorf("txn-total-size-limit should be less than %d", 10<<30)
}

if c.StmtSummary.HistorySize < 0 {
return fmt.Errorf("history-size in [stmt-summary] should be greater than or equal to 0")
}
if c.StmtSummary.RefreshInterval <= 0 {
return fmt.Errorf("refresh-interval in [stmt-summary] should be greater than 0")
}
return nil
}

Expand Down
9 changes: 9 additions & 0 deletions config/config.toml.example
Original file line number Diff line number Diff line change
Expand Up @@ -347,8 +347,17 @@ enable = true
max-retry-count = 256

[stmt-summary]
# enable statement summary.
enable = false

# max number of statements kept in memory.
max-stmt-count = 100

# max length of displayed normalized sql and sample sql.
max-sql-length = 4096

# the refresh interval of statement summary, it's counted in seconds.
refresh-interval = 1800

# the maximum history size of statement summary.
history-size = 24
6 changes: 6 additions & 0 deletions config/config_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -190,8 +190,11 @@ max-batch-size=128
region-cache-ttl=6000
store-limit=0
[stmt-summary]
enable=true
max-stmt-count=1000
max-sql-length=1024
refresh-interval=100
history-size=100
`)

c.Assert(err, IsNil)
Expand All @@ -217,8 +220,11 @@ max-sql-length=1024
c.Assert(conf.EnableTableLock, IsTrue)
c.Assert(conf.DelayCleanTableLock, Equals, uint64(5))
c.Assert(conf.SplitRegionMaxNum, Equals, uint64(10000))
c.Assert(conf.StmtSummary.Enable, Equals, true)
c.Assert(conf.StmtSummary.MaxStmtCount, Equals, uint(1000))
c.Assert(conf.StmtSummary.MaxSQLLength, Equals, uint(1024))
c.Assert(conf.StmtSummary.RefreshInterval, Equals, 100)
c.Assert(conf.StmtSummary.HistorySize, Equals, 100)
c.Assert(conf.EnableBatchDML, Equals, true)
c.Assert(conf.RepairMode, Equals, true)
c.Assert(f.Close(), IsNil)
Expand Down
18 changes: 6 additions & 12 deletions domain/global_vars_cache.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,24 +69,18 @@ func (gvc *GlobalVariableCache) Disable() {
// checkEnableServerGlobalVar processes variables that acts in server and global level.
func checkEnableServerGlobalVar(rows []chunk.Row) {
for _, row := range rows {
sVal := ""
if !row.IsNull(1) {
sVal = row.GetString(1)
}
switch row.GetString(0) {
case variable.TiDBEnableStmtSummary:
sVal := ""
if !row.IsNull(1) {
sVal = row.GetString(1)
}
stmtsummary.StmtSummaryByDigestMap.SetEnabled(sVal, false)
case variable.TiDBStmtSummaryRefreshInterval:
sVal := ""
if !row.IsNull(1) {
sVal = row.GetString(1)
}
stmtsummary.StmtSummaryByDigestMap.SetRefreshInterval(sVal, false)
case variable.TiDBStmtSummaryHistorySize:
stmtsummary.StmtSummaryByDigestMap.SetHistorySize(sVal, false)
case variable.TiDBCapturePlanBaseline:
sVal := ""
if !row.IsNull(1) {
sVal = row.GetString(1)
}
variable.CapturePlanBaseline.Set(sVal, false)
}
}
Expand Down
2 changes: 2 additions & 0 deletions executor/set.go
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,8 @@ func (e *SetExecutor) setSysVariable(name string, v *expression.VarAssignment) e
stmtsummary.StmtSummaryByDigestMap.SetEnabled(valStr, !v.IsGlobal)
case variable.TiDBStmtSummaryRefreshInterval:
stmtsummary.StmtSummaryByDigestMap.SetRefreshInterval(valStr, !v.IsGlobal)
case variable.TiDBStmtSummaryHistorySize:
stmtsummary.StmtSummaryByDigestMap.SetHistorySize(valStr, !v.IsGlobal)
case variable.TiDBCapturePlanBaseline:
variable.CapturePlanBaseline.Set(valStr, !v.IsGlobal)
}
Expand Down
66 changes: 66 additions & 0 deletions infoschema/perfschema/const.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ var perfSchemaTables = []string{
tableStagesHistory,
tableStagesHistoryLong,
tableEventsStatementsSummaryByDigest,
tableEventsStatementsSummaryByDigestHistory,
tableTiDBProfileCPU,
tableTiDBProfileMemory,
tableTiDBProfileMutex,
Expand Down Expand Up @@ -454,6 +455,71 @@ const tableEventsStatementsSummaryByDigest = "CREATE TABLE if not exists " + tab
"LAST_SEEN TIMESTAMP(6) NOT NULL," +
"QUERY_SAMPLE_TEXT LONGTEXT DEFAULT NULL);"

// tableEventsStatementsSummaryByDigestHistory contains the column name definitions for table
// events_statements_summary_by_digest_history.
const tableEventsStatementsSummaryByDigestHistory = "CREATE TABLE if not exists events_statements_summary_by_digest_history (" +
crazycs520 marked this conversation as resolved.
Show resolved Hide resolved
"SUMMARY_BEGIN_TIME TIMESTAMP(6) NOT NULL," +
"STMT_TYPE VARCHAR(64) NOT NULL," +
"SCHEMA_NAME VARCHAR(64) DEFAULT NULL," +
"DIGEST VARCHAR(64) NOT NULL," +
"DIGEST_TEXT LONGTEXT NOT NULL," +
"TABLE_NAMES TEXT DEFAULT NULL," +
"INDEX_NAMES TEXT DEFAULT NULL," +
"SAMPLE_USER VARCHAR(64) DEFAULT NULL," +
"EXEC_COUNT BIGINT(20) UNSIGNED NOT NULL," +
"SUM_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"MAX_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"MIN_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"AVG_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"AVG_PARSE_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"MAX_PARSE_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"AVG_COMPILE_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"MAX_COMPILE_LATENCY BIGINT(20) UNSIGNED NOT NULL," +
"COP_TASK_NUM BIGINT(20) UNSIGNED NOT NULL," +
"AVG_COP_PROCESS_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_COP_PROCESS_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_COP_PROCESS_ADDRESS VARCHAR(256) DEFAULT NULL," +
"AVG_COP_WAIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_COP_WAIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_COP_WAIT_ADDRESS VARCHAR(256) DEFAULT NULL," +
"AVG_PROCESS_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_PROCESS_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_WAIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_WAIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_BACKOFF_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_BACKOFF_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_TOTAL_KEYS BIGINT(20) UNSIGNED NOT NULL," +
"MAX_TOTAL_KEYS BIGINT(20) UNSIGNED NOT NULL," +
"AVG_PROCESSED_KEYS BIGINT(20) UNSIGNED NOT NULL," +
"MAX_PROCESSED_KEYS BIGINT(20) UNSIGNED NOT NULL," +
"AVG_PREWRITE_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_PREWRITE_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_COMMIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_COMMIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_GET_COMMIT_TS_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_GET_COMMIT_TS_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_COMMIT_BACKOFF_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_COMMIT_BACKOFF_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_RESOLVE_LOCK_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_RESOLVE_LOCK_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_LOCAL_LATCH_WAIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"MAX_LOCAL_LATCH_WAIT_TIME BIGINT(20) UNSIGNED NOT NULL," +
"AVG_WRITE_KEYS DOUBLE UNSIGNED NOT NULL," +
"MAX_WRITE_KEYS BIGINT(20) UNSIGNED NOT NULL," +
"AVG_WRITE_SIZE DOUBLE NOT NULL," +
"MAX_WRITE_SIZE BIGINT(20) UNSIGNED NOT NULL," +
"AVG_PREWRITE_REGIONS DOUBLE NOT NULL," +
"MAX_PREWRITE_REGIONS INT(11) UNSIGNED NOT NULL," +
"AVG_TXN_RETRY DOUBLE NOT NULL," +
"MAX_TXN_RETRY INT(11) UNSIGNED NOT NULL," +
"BACKOFF_TYPES VARCHAR(1024) DEFAULT NULL," +
"AVG_MEM BIGINT(20) UNSIGNED NOT NULL," +
"MAX_MEM BIGINT(20) UNSIGNED NOT NULL," +
"AVG_AFFECTED_ROWS DOUBLE UNSIGNED NOT NULL," +
"FIRST_SEEN TIMESTAMP(6) NOT NULL," +
"LAST_SEEN TIMESTAMP(6) NOT NULL," +
"QUERY_SAMPLE_TEXT LONGTEXT DEFAULT NULL);"

// tableTiDBProfileCPU contains the columns name definitions for table tidb_profile_cpu
const tableTiDBProfileCPU = "CREATE TABLE IF NOT EXISTS " + tableNameTiDBProfileCPU + " (" +
"FUNCTION VARCHAR(512) NOT NULL," +
Expand Down
126 changes: 65 additions & 61 deletions infoschema/perfschema/tables.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,69 +37,71 @@ import (
)

const (
tableNameGlobalStatus = "global_status"
tableNameSessionStatus = "session_status"
tableNameSetupActors = "setup_actors"
tableNameSetupObjects = "setup_objects"
tableNameSetupInstruments = "setup_instruments"
tableNameSetupConsumers = "setup_consumers"
tableNameEventsStatementsCurrent = "events_statements_current"
tableNameEventsStatementsHistory = "events_statements_history"
tableNameEventsStatementsHistoryLong = "events_statements_history_long"
tableNamePreparedStatementsInstances = "prepared_statements_instances"
tableNameEventsTransactionsCurrent = "events_transactions_current"
tableNameEventsTransactionsHistory = "events_transactions_history"
tableNameEventsTransactionsHistoryLong = "events_transactions_history_long"
tableNameEventsStagesCurrent = "events_stages_current"
tableNameEventsStagesHistory = "events_stages_history"
tableNameEventsStagesHistoryLong = "events_stages_history_long"
tableNameEventsStatementsSummaryByDigest = "events_statements_summary_by_digest"
tableNameTiDBProfileCPU = "tidb_profile_cpu"
tableNameTiDBProfileMemory = "tidb_profile_memory"
tableNameTiDBProfileMutex = "tidb_profile_mutex"
tableNameTiDBProfileAllocs = "tidb_profile_allocs"
tableNameTiDBProfileBlock = "tidb_profile_block"
tableNameTiDBProfileGoroutines = "tidb_profile_goroutines"
tableNameTiKVProfileCPU = "tikv_profile_cpu"
tableNamePDProfileCPU = "pd_profile_cpu"
tableNamePDProfileMemory = "pd_profile_memory"
tableNamePDProfileMutex = "pd_profile_mutex"
tableNamePDProfileAllocs = "pd_profile_allocs"
tableNamePDProfileBlock = "pd_profile_block"
tableNamePDProfileGoroutines = "pd_profile_goroutines"
tableNameGlobalStatus = "global_status"
tableNameSessionStatus = "session_status"
tableNameSetupActors = "setup_actors"
tableNameSetupObjects = "setup_objects"
tableNameSetupInstruments = "setup_instruments"
tableNameSetupConsumers = "setup_consumers"
tableNameEventsStatementsCurrent = "events_statements_current"
tableNameEventsStatementsHistory = "events_statements_history"
tableNameEventsStatementsHistoryLong = "events_statements_history_long"
tableNamePreparedStatementsInstances = "prepared_statements_instances"
tableNameEventsTransactionsCurrent = "events_transactions_current"
tableNameEventsTransactionsHistory = "events_transactions_history"
tableNameEventsTransactionsHistoryLong = "events_transactions_history_long"
tableNameEventsStagesCurrent = "events_stages_current"
tableNameEventsStagesHistory = "events_stages_history"
tableNameEventsStagesHistoryLong = "events_stages_history_long"
tableNameEventsStatementsSummaryByDigest = "events_statements_summary_by_digest"
tableNameEventsStatementsSummaryByDigestHistory = "events_statements_summary_by_digest_history"
tableNameTiDBProfileCPU = "tidb_profile_cpu"
tableNameTiDBProfileMemory = "tidb_profile_memory"
tableNameTiDBProfileMutex = "tidb_profile_mutex"
tableNameTiDBProfileAllocs = "tidb_profile_allocs"
tableNameTiDBProfileBlock = "tidb_profile_block"
tableNameTiDBProfileGoroutines = "tidb_profile_goroutines"
tableNameTiKVProfileCPU = "tikv_profile_cpu"
tableNamePDProfileCPU = "pd_profile_cpu"
tableNamePDProfileMemory = "pd_profile_memory"
tableNamePDProfileMutex = "pd_profile_mutex"
tableNamePDProfileAllocs = "pd_profile_allocs"
tableNamePDProfileBlock = "pd_profile_block"
tableNamePDProfileGoroutines = "pd_profile_goroutines"
)

var tableIDMap = map[string]int64{
tableNameGlobalStatus: autoid.PerformanceSchemaDBID + 1,
tableNameSessionStatus: autoid.PerformanceSchemaDBID + 2,
tableNameSetupActors: autoid.PerformanceSchemaDBID + 3,
tableNameSetupObjects: autoid.PerformanceSchemaDBID + 4,
tableNameSetupInstruments: autoid.PerformanceSchemaDBID + 5,
tableNameSetupConsumers: autoid.PerformanceSchemaDBID + 6,
tableNameEventsStatementsCurrent: autoid.PerformanceSchemaDBID + 7,
tableNameEventsStatementsHistory: autoid.PerformanceSchemaDBID + 8,
tableNameEventsStatementsHistoryLong: autoid.PerformanceSchemaDBID + 9,
tableNamePreparedStatementsInstances: autoid.PerformanceSchemaDBID + 10,
tableNameEventsTransactionsCurrent: autoid.PerformanceSchemaDBID + 11,
tableNameEventsTransactionsHistory: autoid.PerformanceSchemaDBID + 12,
tableNameEventsTransactionsHistoryLong: autoid.PerformanceSchemaDBID + 13,
tableNameEventsStagesCurrent: autoid.PerformanceSchemaDBID + 14,
tableNameEventsStagesHistory: autoid.PerformanceSchemaDBID + 15,
tableNameEventsStagesHistoryLong: autoid.PerformanceSchemaDBID + 16,
tableNameEventsStatementsSummaryByDigest: autoid.PerformanceSchemaDBID + 17,
tableNameTiDBProfileCPU: autoid.PerformanceSchemaDBID + 18,
tableNameTiDBProfileMemory: autoid.PerformanceSchemaDBID + 19,
tableNameTiDBProfileMutex: autoid.PerformanceSchemaDBID + 20,
tableNameTiDBProfileAllocs: autoid.PerformanceSchemaDBID + 21,
tableNameTiDBProfileBlock: autoid.PerformanceSchemaDBID + 22,
tableNameTiDBProfileGoroutines: autoid.PerformanceSchemaDBID + 23,
tableNameTiKVProfileCPU: autoid.PerformanceSchemaDBID + 24,
tableNamePDProfileCPU: autoid.PerformanceSchemaDBID + 25,
tableNamePDProfileMemory: autoid.PerformanceSchemaDBID + 26,
tableNamePDProfileMutex: autoid.PerformanceSchemaDBID + 27,
tableNamePDProfileAllocs: autoid.PerformanceSchemaDBID + 28,
tableNamePDProfileBlock: autoid.PerformanceSchemaDBID + 29,
tableNamePDProfileGoroutines: autoid.PerformanceSchemaDBID + 30,
tableNameGlobalStatus: autoid.PerformanceSchemaDBID + 1,
tableNameSessionStatus: autoid.PerformanceSchemaDBID + 2,
tableNameSetupActors: autoid.PerformanceSchemaDBID + 3,
tableNameSetupObjects: autoid.PerformanceSchemaDBID + 4,
tableNameSetupInstruments: autoid.PerformanceSchemaDBID + 5,
tableNameSetupConsumers: autoid.PerformanceSchemaDBID + 6,
tableNameEventsStatementsCurrent: autoid.PerformanceSchemaDBID + 7,
tableNameEventsStatementsHistory: autoid.PerformanceSchemaDBID + 8,
tableNameEventsStatementsHistoryLong: autoid.PerformanceSchemaDBID + 9,
tableNamePreparedStatementsInstances: autoid.PerformanceSchemaDBID + 10,
tableNameEventsTransactionsCurrent: autoid.PerformanceSchemaDBID + 11,
tableNameEventsTransactionsHistory: autoid.PerformanceSchemaDBID + 12,
tableNameEventsTransactionsHistoryLong: autoid.PerformanceSchemaDBID + 13,
tableNameEventsStagesCurrent: autoid.PerformanceSchemaDBID + 14,
tableNameEventsStagesHistory: autoid.PerformanceSchemaDBID + 15,
tableNameEventsStagesHistoryLong: autoid.PerformanceSchemaDBID + 16,
tableNameEventsStatementsSummaryByDigest: autoid.PerformanceSchemaDBID + 17,
tableNameTiDBProfileCPU: autoid.PerformanceSchemaDBID + 18,
tableNameTiDBProfileMemory: autoid.PerformanceSchemaDBID + 19,
tableNameTiDBProfileMutex: autoid.PerformanceSchemaDBID + 20,
tableNameTiDBProfileAllocs: autoid.PerformanceSchemaDBID + 21,
tableNameTiDBProfileBlock: autoid.PerformanceSchemaDBID + 22,
tableNameTiDBProfileGoroutines: autoid.PerformanceSchemaDBID + 23,
tableNameTiKVProfileCPU: autoid.PerformanceSchemaDBID + 24,
tableNamePDProfileCPU: autoid.PerformanceSchemaDBID + 25,
tableNamePDProfileMemory: autoid.PerformanceSchemaDBID + 26,
tableNamePDProfileMutex: autoid.PerformanceSchemaDBID + 27,
tableNamePDProfileAllocs: autoid.PerformanceSchemaDBID + 28,
tableNamePDProfileBlock: autoid.PerformanceSchemaDBID + 29,
tableNamePDProfileGoroutines: autoid.PerformanceSchemaDBID + 30,
tableNameEventsStatementsSummaryByDigestHistory: autoid.PerformanceSchemaDBID + 31,
}

// perfSchemaTable stands for the fake table all its data is in the memory.
Expand Down Expand Up @@ -163,7 +165,9 @@ func (vt *perfSchemaTable) Meta() *model.TableInfo {
func (vt *perfSchemaTable) getRows(ctx sessionctx.Context, cols []*table.Column) (fullRows [][]types.Datum, err error) {
switch vt.meta.Name.O {
case tableNameEventsStatementsSummaryByDigest:
fullRows = stmtsummary.StmtSummaryByDigestMap.ToDatum()
fullRows = stmtsummary.StmtSummaryByDigestMap.ToCurrentDatum()
case tableNameEventsStatementsSummaryByDigestHistory:
fullRows = stmtsummary.StmtSummaryByDigestMap.ToHistoryDatum()
case tableNameTiDBProfileCPU:
fullRows, err = (&profile.Collector{}).ProfileGraph("cpu")
case tableNameTiDBProfileMemory:
Expand Down
Loading