diff options
author | Thomas Guyot-Sionnest <dermoth@aei.ca> | 2009-03-24 02:01:48 -0400 |
---|---|---|
committer | Thomas Guyot-Sionnest <dermoth@aei.ca> | 2009-03-24 02:01:48 -0400 |
commit | ab3ada9aacd82356a6e5205f3ae26bbff55524db (patch) | |
tree | c80b7aee657b34d8f018c94cac45ece1507f4c26 /plugins/check_mysql.c | |
parent | f2f2f35240c976ddc6e44cd6276df88aad812199 (diff) | |
download | monitoring-plugins-ab3ada9aacd82356a6e5205f3ae26bbff55524db.tar.gz |
check_mysql: Fix segfault with old slaves (#2696823 - Oskar Ahner)
Diffstat (limited to 'plugins/check_mysql.c')
-rw-r--r-- | plugins/check_mysql.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/plugins/check_mysql.c b/plugins/check_mysql.c index 119ce0af..689648eb 100644 --- a/plugins/check_mysql.c +++ b/plugins/check_mysql.c @@ -177,13 +177,14 @@ main (int argc, char **argv) continue; } } + if ((slave_io_field < 0) || (slave_sql_field < 0) || (num_fields == 0)) { mysql_free_result (res); mysql_close (&mysql); die (STATE_CRITICAL, "Slave status unavailable\n"); } - snprintf (slaveresult, SLAVERESULTSIZE, "Slave IO: %s Slave SQL: %s Seconds Behind Master: %s", row[slave_io_field], row[slave_sql_field], row[seconds_behind_field]); + snprintf (slaveresult, SLAVERESULTSIZE, "Slave IO: %s Slave SQL: %s Seconds Behind Master: %s", row[slave_io_field], row[slave_sql_field], seconds_behind_field!=-1?row[seconds_behind_field]:"Unknown"); if (strcmp (row[slave_io_field], "Yes") != 0 || strcmp (row[slave_sql_field], "Yes") != 0) { mysql_free_result (res); mysql_close (&mysql); |