mysql plugin, check for existence of table before scanning
This commit is contained in:
		
							parent
							
								
									b16bc3d2e3
								
							
						
					
					
						commit
						c121e38da6
					
				|  | @ -367,6 +367,12 @@ const ( | |||
|             FROM information_schema.schemata | ||||
|         WHERE SCHEMA_NAME NOT IN ('mysql', 'performance_schema', 'information_schema') | ||||
|     ` | ||||
| 	perfSchemaTablesQuery = ` | ||||
| 		SELECT | ||||
| 			table_name | ||||
| 			FROM information_schema.tables | ||||
| 		WHERE table_schema = 'performance_schema' AND table_name = ? | ||||
| 	` | ||||
| ) | ||||
| 
 | ||||
| func (m *Mysql) gatherServer(serv string, acc telegraf.Accumulator) error { | ||||
|  | @ -847,6 +853,18 @@ func (m *Mysql) gatherInfoSchemaAutoIncStatuses(db *sql.DB, serv string, acc tel | |||
| // the total number and time for SQL and external lock wait events
 | ||||
| // for each table and operation
 | ||||
| func (m *Mysql) gatherPerfTableLockWaits(db *sql.DB, serv string, acc telegraf.Accumulator) error { | ||||
| 	// check if table exists,
 | ||||
| 	// if performance_schema is not enabled, tables do not exist
 | ||||
| 	// then there is no need to scan them
 | ||||
| 	var tableName string | ||||
| 	err := db.QueryRow(perfSchemaTablesQuery, "table_lock_waits_summary_by_table").Scan(&tableName) | ||||
| 	switch { | ||||
| 	case err == sql.ErrNoRows: | ||||
| 		return nil | ||||
| 	case err != nil: | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	rows, err := db.Query(perfTableLockWaitsQuery) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue