Commit 613dd62a authored by Sergey Vojtovich's avatar Sergey Vojtovich

MDEV-11153 - Introduce status variables for table cache monitoring and tuning

Status variables added: Table_open_cache_hits, Table_open_cache_misses,
Table_open_cache_overflows, Table_open_cache_active_instances.
parent 5d3ed9ac
...@@ -386,6 +386,29 @@ Handler_tmp_write 2 ...@@ -386,6 +386,29 @@ Handler_tmp_write 2
Handler_update 0 Handler_update 0
Handler_write 0 Handler_write 0
drop table t1; drop table t1;
#
# MDEV-11153 - Introduce status variables for table cache monitoring and
# tuning
#
SET @old_table_open_cache= @@table_open_cache;
SET @@global.table_open_cache=10;
FLUSH TABLES;
FLUSH STATUS;
SHOW STATUS LIKE 'Table_open_cache%';
Variable_name Value
Table_open_cache_active_instances 1
Table_open_cache_hits 0
Table_open_cache_misses 0
Table_open_cache_overflows 0
SHOW STATUS LIKE 'Table_open_cache%';
Variable_name Value
Table_open_cache_active_instances 1
Table_open_cache_hits 30
Table_open_cache_misses 15
Table_open_cache_overflows 5
FLUSH TABLES;
FLUSH STATUS;
SET @@global.table_open_cache= @old_table_open_cache;
connection default; connection default;
set @@global.concurrent_insert= @old_concurrent_insert; set @@global.concurrent_insert= @old_concurrent_insert;
SET GLOBAL log_output = @old_log_output; SET GLOBAL log_output = @old_log_output;
...@@ -387,6 +387,39 @@ drop table t1; ...@@ -387,6 +387,39 @@ drop table t1;
# End of 5.3 tests # End of 5.3 tests
--echo #
--echo # MDEV-11153 - Introduce status variables for table cache monitoring and
--echo # tuning
--echo #
SET @old_table_open_cache= @@table_open_cache;
SET @@global.table_open_cache=10;
FLUSH TABLES;
FLUSH STATUS;
SHOW STATUS LIKE 'Table_open_cache%';
disable_query_log;
let $i= `SELECT @@table_open_cache + 5`;
while ($i)
{
eval CREATE TABLE t$i(a INT);
eval DELETE FROM t$i;
eval DELETE FROM t$i;
eval DELETE FROM t$i;
dec $i;
}
enable_query_log;
SHOW STATUS LIKE 'Table_open_cache%';
FLUSH TABLES;
FLUSH STATUS;
disable_query_log;
let $i= `SELECT @@table_open_cache + 5`;
while ($i)
{
eval DROP TABLE t$i;
dec $i;
}
enable_query_log;
SET @@global.table_open_cache= @old_table_open_cache;
# Restore global concurrent_insert value. Keep in the end of the test file. # Restore global concurrent_insert value. Keep in the end of the test file.
--connection default --connection default
set @@global.concurrent_insert= @old_concurrent_insert; set @@global.concurrent_insert= @old_concurrent_insert;
......
...@@ -8616,6 +8616,10 @@ SHOW_VAR status_vars[]= { ...@@ -8616,6 +8616,10 @@ SHOW_VAR status_vars[]= {
{"Subquery_cache_miss", (char*) &subquery_cache_miss, SHOW_LONG}, {"Subquery_cache_miss", (char*) &subquery_cache_miss, SHOW_LONG},
{"Table_locks_immediate", (char*) &locks_immediate, SHOW_LONG}, {"Table_locks_immediate", (char*) &locks_immediate, SHOW_LONG},
{"Table_locks_waited", (char*) &locks_waited, SHOW_LONG}, {"Table_locks_waited", (char*) &locks_waited, SHOW_LONG},
{"Table_open_cache_active_instances", (char*) &tc_active_instances, SHOW_UINT},
{"Table_open_cache_hits", (char*) offsetof(STATUS_VAR, table_open_cache_hits), SHOW_LONGLONG_STATUS},
{"Table_open_cache_misses", (char*) offsetof(STATUS_VAR, table_open_cache_misses), SHOW_LONGLONG_STATUS},
{"Table_open_cache_overflows", (char*) offsetof(STATUS_VAR, table_open_cache_overflows), SHOW_LONGLONG_STATUS},
#ifdef HAVE_MMAP #ifdef HAVE_MMAP
{"Tc_log_max_pages_used", (char*) &tc_log_max_pages_used, SHOW_LONG}, {"Tc_log_max_pages_used", (char*) &tc_log_max_pages_used, SHOW_LONG},
{"Tc_log_page_size", (char*) &tc_log_page_size, SHOW_LONG_NOFLUSH}, {"Tc_log_page_size", (char*) &tc_log_page_size, SHOW_LONG_NOFLUSH},
......
...@@ -1728,6 +1728,9 @@ void add_to_status(STATUS_VAR *to_var, STATUS_VAR *from_var) ...@@ -1728,6 +1728,9 @@ void add_to_status(STATUS_VAR *to_var, STATUS_VAR *from_var)
to_var->binlog_bytes_written+= from_var->binlog_bytes_written; to_var->binlog_bytes_written+= from_var->binlog_bytes_written;
to_var->cpu_time+= from_var->cpu_time; to_var->cpu_time+= from_var->cpu_time;
to_var->busy_time+= from_var->busy_time; to_var->busy_time+= from_var->busy_time;
to_var->table_open_cache_hits+= from_var->table_open_cache_hits;
to_var->table_open_cache_misses+= from_var->table_open_cache_misses;
to_var->table_open_cache_overflows+= from_var->table_open_cache_overflows;
/* /*
Update global_memory_used. We have to do this with atomic_add as the Update global_memory_used. We have to do this with atomic_add as the
...@@ -1779,6 +1782,12 @@ void add_diff_to_status(STATUS_VAR *to_var, STATUS_VAR *from_var, ...@@ -1779,6 +1782,12 @@ void add_diff_to_status(STATUS_VAR *to_var, STATUS_VAR *from_var,
dec_var->binlog_bytes_written; dec_var->binlog_bytes_written;
to_var->cpu_time+= from_var->cpu_time - dec_var->cpu_time; to_var->cpu_time+= from_var->cpu_time - dec_var->cpu_time;
to_var->busy_time+= from_var->busy_time - dec_var->busy_time; to_var->busy_time+= from_var->busy_time - dec_var->busy_time;
to_var->table_open_cache_hits+= from_var->table_open_cache_hits -
dec_var->table_open_cache_hits;
to_var->table_open_cache_misses+= from_var->table_open_cache_misses -
dec_var->table_open_cache_misses;
to_var->table_open_cache_overflows+= from_var->table_open_cache_overflows -
dec_var->table_open_cache_overflows;
/* /*
We don't need to accumulate memory_used as these are not reset or used by We don't need to accumulate memory_used as these are not reset or used by
......
...@@ -823,6 +823,9 @@ typedef struct system_status_var ...@@ -823,6 +823,9 @@ typedef struct system_status_var
ulonglong rows_sent; ulonglong rows_sent;
ulonglong rows_tmp_read; ulonglong rows_tmp_read;
ulonglong binlog_bytes_written; ulonglong binlog_bytes_written;
ulonglong table_open_cache_hits;
ulonglong table_open_cache_misses;
ulonglong table_open_cache_overflows;
double last_query_cost; double last_query_cost;
double cpu_time, busy_time; double cpu_time, busy_time;
/* Don't initialize */ /* Don't initialize */
......
...@@ -56,7 +56,7 @@ ...@@ -56,7 +56,7 @@
ulong tdc_size; /**< Table definition cache threshold for LRU eviction. */ ulong tdc_size; /**< Table definition cache threshold for LRU eviction. */
ulong tc_size; /**< Table cache threshold for LRU eviction. */ ulong tc_size; /**< Table cache threshold for LRU eviction. */
uint32 tc_instances; uint32 tc_instances;
static uint32 tc_active_instances= 1; uint32 tc_active_instances= 1;
static uint32 tc_contention_warning_reported; static uint32 tc_contention_warning_reported;
/** Data collections. */ /** Data collections. */
...@@ -369,18 +369,30 @@ void tc_add_table(THD *thd, TABLE *table) ...@@ -369,18 +369,30 @@ void tc_add_table(THD *thd, TABLE *table)
mysql_mutex_unlock(&element->LOCK_table_share); mysql_mutex_unlock(&element->LOCK_table_share);
mysql_mutex_lock(&tc[i].LOCK_table_cache); mysql_mutex_lock(&tc[i].LOCK_table_cache);
if (tc[i].records == tc_size && (LRU_table= tc[i].free_tables.pop_front())) if (tc[i].records == tc_size)
{ {
LRU_table->s->tdc->free_tables[i].list.remove(LRU_table); if ((LRU_table= tc[i].free_tables.pop_front()))
/* Needed if MDL deadlock detector chimes in before tc_remove_table() */ {
LRU_table->in_use= thd; LRU_table->s->tdc->free_tables[i].list.remove(LRU_table);
/* Needed if MDL deadlock detector chimes in before tc_remove_table() */
LRU_table->in_use= thd;
mysql_mutex_unlock(&tc[i].LOCK_table_cache);
/* Keep out of locked LOCK_table_cache */
tc_remove_table(LRU_table);
}
else
{
tc[i].records++;
mysql_mutex_unlock(&tc[i].LOCK_table_cache);
}
/* Keep out of locked LOCK_table_cache */
status_var_increment(thd->status_var.table_open_cache_overflows);
} }
else else
{
tc[i].records++; tc[i].records++;
mysql_mutex_unlock(&tc[i].LOCK_table_cache); mysql_mutex_unlock(&tc[i].LOCK_table_cache);
}
if (LRU_table)
tc_remove_table(LRU_table);
} }
...@@ -841,7 +853,10 @@ TABLE_SHARE *tdc_acquire_share(THD *thd, TABLE_LIST *tl, uint flags, ...@@ -841,7 +853,10 @@ TABLE_SHARE *tdc_acquire_share(THD *thd, TABLE_LIST *tl, uint flags,
tdc_purge(false); tdc_purge(false);
if (out_table) if (out_table)
{
status_var_increment(thd->status_var.table_open_cache_misses);
*out_table= 0; *out_table= 0;
}
share->m_psi= PSI_CALL_get_table_share(false, share); share->m_psi= PSI_CALL_get_table_share(false, share);
goto end; goto end;
} }
...@@ -858,8 +873,10 @@ TABLE_SHARE *tdc_acquire_share(THD *thd, TABLE_LIST *tl, uint flags, ...@@ -858,8 +873,10 @@ TABLE_SHARE *tdc_acquire_share(THD *thd, TABLE_LIST *tl, uint flags,
DBUG_ASSERT(element->share); DBUG_ASSERT(element->share);
DBUG_ASSERT(!element->share->error); DBUG_ASSERT(!element->share->error);
DBUG_ASSERT(!element->share->is_view); DBUG_ASSERT(!element->share->is_view);
status_var_increment(thd->status_var.table_open_cache_hits);
DBUG_RETURN(element->share); DBUG_RETURN(element->share);
} }
status_var_increment(thd->status_var.table_open_cache_misses);
} }
mysql_mutex_lock(&element->LOCK_table_share); mysql_mutex_lock(&element->LOCK_table_share);
......
...@@ -71,6 +71,7 @@ enum enum_tdc_remove_table_type ...@@ -71,6 +71,7 @@ enum enum_tdc_remove_table_type
extern ulong tdc_size; extern ulong tdc_size;
extern ulong tc_size; extern ulong tc_size;
extern uint32 tc_instances; extern uint32 tc_instances;
extern uint32 tc_active_instances;
extern bool tdc_init(void); extern bool tdc_init(void);
extern void tdc_start_shutdown(void); extern void tdc_start_shutdown(void);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment