Commit 8311eae6 authored by Nikita Malyavin's avatar Nikita Malyavin

online alter: use thd->ha_data to store cache_list

parent cb521746
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
static handlerton *online_alter_hton; static handlerton *online_alter_hton;
typedef ilist<online_alter_cache_data> Online_alter_cache_list;
class online_alter_cache_data: public Sql_alloc, public ilist_node<>, class online_alter_cache_data: public Sql_alloc, public ilist_node<>,
public binlog_cache_data public binlog_cache_data
...@@ -68,12 +69,31 @@ online_alter_cache_data *setup_cache_data(MEM_ROOT *root, TABLE_SHARE *share) ...@@ -68,12 +69,31 @@ online_alter_cache_data *setup_cache_data(MEM_ROOT *root, TABLE_SHARE *share)
} }
static online_alter_cache_data *get_cache_data(THD *thd, TABLE *table) static Online_alter_cache_list &get_cache_list(handlerton *ht, THD *thd)
{ {
ilist<online_alter_cache_data> &list= thd->online_alter_cache_list; void *data= thd_get_ha_data(thd, ht);
DBUG_ASSERT(data);
return *(Online_alter_cache_list*)data;
}
static Online_alter_cache_list &get_or_create_cache_list(THD *thd)
{
void *data= thd_get_ha_data(thd, online_alter_hton);
if (!data)
{
data= new Online_alter_cache_list();
thd_set_ha_data(thd, online_alter_hton, data);
}
return *(Online_alter_cache_list*)data;
}
static online_alter_cache_data* get_cache_data(THD *thd, TABLE *table)
{
auto &cache_list= get_or_create_cache_list(thd);
/* we assume it's very rare to have more than one online ALTER running */ /* we assume it's very rare to have more than one online ALTER running */
for (auto &cache: list) for (auto &cache: cache_list)
{ {
if (cache.sink_log == table->s->online_alter_binlog) if (cache.sink_log == table->s->online_alter_binlog)
return &cache; return &cache;
...@@ -81,7 +101,7 @@ static online_alter_cache_data *get_cache_data(THD *thd, TABLE *table) ...@@ -81,7 +101,7 @@ static online_alter_cache_data *get_cache_data(THD *thd, TABLE *table)
MEM_ROOT *root= &thd->transaction->mem_root; MEM_ROOT *root= &thd->transaction->mem_root;
auto *new_cache_data= setup_cache_data(root, table->s); auto *new_cache_data= setup_cache_data(root, table->s);
list.push_back(*new_cache_data); cache_list.push_back(*new_cache_data);
return new_cache_data; return new_cache_data;
} }
...@@ -148,12 +168,13 @@ int online_alter_end_trans(handlerton *hton, THD *thd, bool all, bool commit) ...@@ -148,12 +168,13 @@ int online_alter_end_trans(handlerton *hton, THD *thd, bool all, bool commit)
{ {
DBUG_ENTER("online_alter_end_trans"); DBUG_ENTER("online_alter_end_trans");
int error= 0; int error= 0;
if (thd->online_alter_cache_list.empty()) auto &cache_list= get_cache_list(hton, thd);
if (cache_list.empty())
DBUG_RETURN(0); DBUG_RETURN(0);
bool is_ending_transaction= ending_trans(thd, all); bool is_ending_transaction= ending_trans(thd, all);
for (auto &cache: thd->online_alter_cache_list) for (auto &cache: cache_list)
{ {
auto *binlog= cache.sink_log; auto *binlog= cache.sink_log;
DBUG_ASSERT(binlog); DBUG_ASSERT(binlog);
...@@ -197,14 +218,12 @@ int online_alter_end_trans(handlerton *hton, THD *thd, bool all, bool commit) ...@@ -197,14 +218,12 @@ int online_alter_end_trans(handlerton *hton, THD *thd, bool all, bool commit)
{ {
my_error(ER_ERROR_ON_WRITE, MYF(ME_ERROR_LOG), my_error(ER_ERROR_ON_WRITE, MYF(ME_ERROR_LOG),
binlog->get_name(), errno); binlog->get_name(), errno);
cleanup_cache_list(thd->online_alter_cache_list, cleanup_cache_list(cache_list, is_ending_transaction);
is_ending_transaction);
DBUG_RETURN(error); DBUG_RETURN(error);
} }
} }
cleanup_cache_list(thd->online_alter_cache_list, cleanup_cache_list(cache_list, is_ending_transaction);
is_ending_transaction);
for (TABLE *table= thd->open_tables; table; table= table->next) for (TABLE *table= thd->open_tables; table; table= table->next)
table->online_alter_cache= NULL; table->online_alter_cache= NULL;
...@@ -220,13 +239,14 @@ SAVEPOINT* savepoint_add(THD *thd, LEX_CSTRING name, SAVEPOINT **list, ...@@ -220,13 +239,14 @@ SAVEPOINT* savepoint_add(THD *thd, LEX_CSTRING name, SAVEPOINT **list,
int online_alter_savepoint_set(THD *thd, LEX_CSTRING name) int online_alter_savepoint_set(THD *thd, LEX_CSTRING name)
{ {
DBUG_ENTER("binlog_online_alter_savepoint"); DBUG_ENTER("binlog_online_alter_savepoint");
if (thd->online_alter_cache_list.empty()) auto &cache_list= get_cache_list(online_alter_hton, thd);
if (cache_list.empty())
DBUG_RETURN(0); DBUG_RETURN(0);
if (savepoint_alloc_size < sizeof (SAVEPOINT) + sizeof(my_off_t)) if (savepoint_alloc_size < sizeof (SAVEPOINT) + sizeof(my_off_t))
savepoint_alloc_size= sizeof (SAVEPOINT) + sizeof(my_off_t); savepoint_alloc_size= sizeof (SAVEPOINT) + sizeof(my_off_t);
for (auto &cache: thd->online_alter_cache_list) for (auto &cache: cache_list)
{ {
if (cache.hton->savepoint_set == NULL) if (cache.hton->savepoint_set == NULL)
continue; continue;
...@@ -246,7 +266,9 @@ int online_alter_savepoint_set(THD *thd, LEX_CSTRING name) ...@@ -246,7 +266,9 @@ int online_alter_savepoint_set(THD *thd, LEX_CSTRING name)
int online_alter_savepoint_rollback(THD *thd, LEX_CSTRING name) int online_alter_savepoint_rollback(THD *thd, LEX_CSTRING name)
{ {
DBUG_ENTER("online_alter_savepoint_rollback"); DBUG_ENTER("online_alter_savepoint_rollback");
for (auto &cache: thd->online_alter_cache_list)
auto &cache_list= get_cache_list(online_alter_hton, thd);
for (auto &cache: cache_list)
{ {
if (cache.hton->savepoint_set == NULL) if (cache.hton->savepoint_set == NULL)
continue; continue;
...@@ -264,7 +286,11 @@ int online_alter_savepoint_rollback(THD *thd, LEX_CSTRING name) ...@@ -264,7 +286,11 @@ int online_alter_savepoint_rollback(THD *thd, LEX_CSTRING name)
static int online_alter_close_connection(handlerton *hton, THD *thd) static int online_alter_close_connection(handlerton *hton, THD *thd)
{ {
DBUG_ASSERT(thd->online_alter_cache_list.empty()); auto *cache_list= (Online_alter_cache_list*)thd_get_ha_data(thd, hton);
DBUG_ASSERT(!cache_list || cache_list->empty());
delete cache_list;
thd_set_ha_data(thd, hton, NULL);
return 0; return 0;
} }
......
...@@ -5634,8 +5634,6 @@ class THD: public THD_count, /* this must be first */ ...@@ -5634,8 +5634,6 @@ class THD: public THD_count, /* this must be first */
Item *sp_prepare_func_item(Item **it_addr, uint cols); Item *sp_prepare_func_item(Item **it_addr, uint cols);
bool sp_eval_expr(Field *result_field, Item **expr_item_ptr); bool sp_eval_expr(Field *result_field, Item **expr_item_ptr);
ilist<online_alter_cache_data> online_alter_cache_list;
bool sql_parser(LEX *old_lex, LEX *lex, bool sql_parser(LEX *old_lex, LEX *lex,
char *str, uint str_len, bool stmt_prepare_mode); char *str, uint str_len, bool stmt_prepare_mode);
......
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