transposed the matrix of tags/fields for Lock Waits stats gathering
This commit is contained in:
parent
7e64dc380f
commit
a2d1ee08d4
|
@ -1157,123 +1157,52 @@ func (m *Mysql) gatherPerfTableLockWaits(db *sql.DB, serv string, acc telegraf.A
|
||||||
"schema": objectSchema,
|
"schema": objectSchema,
|
||||||
"table": objectName,
|
"table": objectName,
|
||||||
}
|
}
|
||||||
sqlLWFields := make(map[string]interface{})
|
|
||||||
|
|
||||||
rnTags := copyTags(tags)
|
sqlLWTags := copyTags(tags)
|
||||||
rnTags["operation"] = "read_normal"
|
sqlLWTags["perf_query"] = "sql_lock_waits_total"
|
||||||
sqlLWFields["sql_lock_waits_total"] = countReadNormal
|
sqlLWFields := map[string]interface{}{
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, rnTags)
|
"read_normal": countReadNormal,
|
||||||
|
"read_with_shared_locks": countReadWithSharedLocks,
|
||||||
|
"read_high_priority": countReadHighPriority,
|
||||||
|
"read_no_insert": countReadNoInsert,
|
||||||
|
"write_normal": countWriteNormal,
|
||||||
|
"write_allow_write": countWriteAllowWrite,
|
||||||
|
"write_concurrent_insert": countWriteConcurrentInsert,
|
||||||
|
"write_delayed": countWriteDelayed,
|
||||||
|
"write_low_priority": countWriteLowPriority,
|
||||||
|
}
|
||||||
|
acc.AddFields("mysql_perf_schema", sqlLWFields, sqlLWTags)
|
||||||
|
|
||||||
rwslTags := copyTags(tags)
|
externalLWTags := copyTags(tags)
|
||||||
rwslTags["operation"] = "read_with_shared_locks"
|
externalLWTags["perf_query"] = "external_lock_waits_total"
|
||||||
sqlLWFields["sql_lock_waits_total"] = countReadWithSharedLocks
|
externalLWFields := map[string]interface{}{
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, rwslTags)
|
"read": countReadExternal,
|
||||||
|
"write": countWriteExternal,
|
||||||
|
}
|
||||||
|
acc.AddFields("mysql_perf_schema", externalLWFields, externalLWTags)
|
||||||
|
|
||||||
rhptTags := copyTags(tags)
|
sqlLWSecTotalTags := copyTags(tags)
|
||||||
rhptTags["operation"] = "read_high_priority"
|
sqlLWSecTotalTags["perf_query"] = "sql_lock_waits_seconds_total"
|
||||||
sqlLWFields["sql_lock_waits_total"] = countReadHighPriority
|
sqlLWSecTotalFields := map[string]interface{}{
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, rhptTags)
|
"read_normal": timeReadNormal / picoSeconds,
|
||||||
|
"read_with_shared_locks": timeReadWithSharedLocks / picoSeconds,
|
||||||
|
"read_high_priority": timeReadHighPriority / picoSeconds,
|
||||||
|
"read_no_insert": timeReadNoInsert / picoSeconds,
|
||||||
|
"write_normal": timeWriteNormal / picoSeconds,
|
||||||
|
"write_allow_write": timeWriteAllowWrite / picoSeconds,
|
||||||
|
"write_concurrent_insert": timeWriteConcurrentInsert / picoSeconds,
|
||||||
|
"write_delayed": timeWriteDelayed / picoSeconds,
|
||||||
|
"write_low_priority": timeWriteLowPriority / picoSeconds,
|
||||||
|
}
|
||||||
|
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, sqlLWSecTotalTags)
|
||||||
|
|
||||||
rniTags := copyTags(tags)
|
externalLWSecTotalTags := copyTags(tags)
|
||||||
rniTags["operation"] = "read_no_insert"
|
externalLWSecTotalTags["perf_query"] = "external_lock_waits_seconds_total"
|
||||||
sqlLWFields["sql_lock_waits_total"] = countReadNoInsert
|
externalLWSecTotalFields := map[string]interface{}{
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, tags)
|
"read": timeReadExternal / picoSeconds,
|
||||||
|
"write": timeWriteExternal / picoSeconds,
|
||||||
wnTags := copyTags(tags)
|
}
|
||||||
wnTags["operation"] = "write_normal"
|
acc.AddFields("mysql_perf_schema", externalLWSecTotalFields, externalLWSecTotalTags)
|
||||||
sqlLWFields["sql_lock_waits_total"] = countWriteNormal
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, wnTags)
|
|
||||||
|
|
||||||
wawTags := copyTags(tags)
|
|
||||||
wawTags["operation"] = "write_allow_write"
|
|
||||||
sqlLWFields["sql_lock_waits_total"] = countWriteAllowWrite
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, wawTags)
|
|
||||||
|
|
||||||
wciTags := copyTags(tags)
|
|
||||||
wciTags["operation"] = "write_concurrent_insert"
|
|
||||||
sqlLWFields["sql_lock_waits_total"] = countWriteConcurrentInsert
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, wciTags)
|
|
||||||
|
|
||||||
wdTags := copyTags(tags)
|
|
||||||
wdTags["operation"] = "write_delayed"
|
|
||||||
sqlLWFields["sql_lock_waits_total"] = countWriteDelayed
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, wdTags)
|
|
||||||
|
|
||||||
wlpTags := copyTags(tags)
|
|
||||||
wlpTags["operation"] = "write_low_priority"
|
|
||||||
sqlLWFields["sql_lock_waits_total"] = countWriteLowPriority
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWFields, wlpTags)
|
|
||||||
|
|
||||||
externalLWFields := make(map[string]interface{})
|
|
||||||
|
|
||||||
rTags := copyTags(tags)
|
|
||||||
rTags["operation"] = "read"
|
|
||||||
externalLWFields["external_lock_waits_total"] = countReadExternal
|
|
||||||
acc.AddFields("mysql_perf_schema", externalLWFields, rTags)
|
|
||||||
|
|
||||||
wTags := copyTags(tags)
|
|
||||||
wTags["operation"] = "write"
|
|
||||||
externalLWFields["external_lock_waits_total"] = countWriteExternal
|
|
||||||
acc.AddFields("mysql_perf_schema", externalLWFields, wTags)
|
|
||||||
|
|
||||||
sqlLWSecTotalFields := make(map[string]interface{})
|
|
||||||
|
|
||||||
rnstTags := copyTags(tags)
|
|
||||||
rnstTags["operation"] = "read_normal"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeReadNormal / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, rnstTags)
|
|
||||||
|
|
||||||
rwslstTags := copyTags(tags)
|
|
||||||
rwslstTags["operation"] = "read_with_shared_locks"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeReadWithSharedLocks / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, rwslstTags)
|
|
||||||
|
|
||||||
rhpTags := copyTags(tags)
|
|
||||||
rhpTags["operation"] = "read_high_priority"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeReadHighPriority / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, rhpTags)
|
|
||||||
|
|
||||||
rnistTags := copyTags(tags)
|
|
||||||
rnistTags["operation"] = "read_no_insert"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeReadNoInsert / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, rnistTags)
|
|
||||||
|
|
||||||
wnstTags := copyTags(tags)
|
|
||||||
wnstTags["operation"] = "write_normal"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeWriteNormal / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, wnstTags)
|
|
||||||
|
|
||||||
wawstTags := copyTags(tags)
|
|
||||||
wawstTags["operation"] = "write_allow_write"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeWriteAllowWrite / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, wawstTags)
|
|
||||||
|
|
||||||
wcistTags := copyTags(tags)
|
|
||||||
wcistTags["operation"] = "write_concurrent_insert"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeWriteConcurrentInsert / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, wcistTags)
|
|
||||||
|
|
||||||
wdstTags := copyTags(tags)
|
|
||||||
wdstTags["operation"] = "write_delayed"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeWriteDelayed / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, wdstTags)
|
|
||||||
|
|
||||||
wlpstTags := copyTags(tags)
|
|
||||||
wlpstTags["operation"] = "write_low_priority"
|
|
||||||
sqlLWSecTotalFields["sql_lock_waits_seconds_total"] = timeWriteLowPriority / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", sqlLWSecTotalFields, wlpstTags)
|
|
||||||
|
|
||||||
externalLWSecTotalFields := make(map[string]interface{})
|
|
||||||
|
|
||||||
rstTags := copyTags(tags)
|
|
||||||
rstTags["operation"] = "read"
|
|
||||||
externalLWSecTotalFields["external_lock_waits_seconds_total"] = timeReadExternal / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", externalLWSecTotalFields, rstTags)
|
|
||||||
|
|
||||||
wstTags := copyTags(tags)
|
|
||||||
wstTags["operation"] = "write"
|
|
||||||
externalLWSecTotalFields["external_lock_waits_seconds_total"] = timeWriteExternal / picoSeconds
|
|
||||||
acc.AddFields("mysql_perf_schema", externalLWSecTotalFields, wstTags)
|
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue