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 |             FROM information_schema.schemata | ||||||
|         WHERE SCHEMA_NAME NOT IN ('mysql', 'performance_schema', 'information_schema') |         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 { | 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
 | // the total number and time for SQL and external lock wait events
 | ||||||
| // for each table and operation
 | // for each table and operation
 | ||||||
| func (m *Mysql) gatherPerfTableLockWaits(db *sql.DB, serv string, acc telegraf.Accumulator) error { | 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) | 	rows, err := db.Query(perfTableLockWaitsQuery) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue