diff options
Diffstat (limited to 'sql/sql_parse.cc')
| -rw-r--r-- | sql/sql_parse.cc | 26 | 
1 files changed, 20 insertions, 6 deletions
| diff --git a/sql/sql_parse.cc b/sql/sql_parse.cc index 3ec7b54e0a9..dd16200539d 100644 --- a/sql/sql_parse.cc +++ b/sql/sql_parse.cc @@ -724,6 +724,9 @@ void init_update_queries(void)    sql_command_flags[SQLCOM_TRUNCATE]|= CF_FORCE_ORIGINAL_BINLOG_FORMAT;    /* We don't want to replicate DROP for temp tables in row format */    sql_command_flags[SQLCOM_DROP_TABLE]|= CF_FORCE_ORIGINAL_BINLOG_FORMAT; +  /* We don't want to replicate CREATE/DROP INDEX for temp tables in row format */ +  sql_command_flags[SQLCOM_CREATE_INDEX]|= CF_FORCE_ORIGINAL_BINLOG_FORMAT; +  sql_command_flags[SQLCOM_DROP_INDEX]|= CF_FORCE_ORIGINAL_BINLOG_FORMAT;    /* One can change replication mode with SET */    sql_command_flags[SQLCOM_SET_OPTION]|= CF_FORCE_ORIGINAL_BINLOG_FORMAT; @@ -1577,10 +1580,10 @@ bool dispatch_command(enum enum_server_command command, THD *thd,      if (thd->wsrep_conflict_state == ABORTED &&          command != COM_STMT_CLOSE && command != COM_QUIT)      { +      mysql_mutex_unlock(&thd->LOCK_thd_data);        my_message(ER_LOCK_DEADLOCK, "Deadlock: wsrep aborted transaction",                   MYF(0));        WSREP_DEBUG("Deadlock error for: %s", thd->query()); -      mysql_mutex_unlock(&thd->LOCK_thd_data);        thd->reset_killed();        thd->mysys_var->abort     = 0;        thd->wsrep_conflict_state = NO_CONFLICT; @@ -7826,36 +7829,46 @@ static void wsrep_mysql_parse(THD *thd, char *rawbuf, uint length,              thd->lex->sql_command != SQLCOM_SELECT  &&              (thd->wsrep_retry_counter < thd->variables.wsrep_retry_autocommit))          { -          WSREP_DEBUG("wsrep retrying AC query: %s",  +          mysql_mutex_unlock(&thd->LOCK_thd_data); +          WSREP_DEBUG("wsrep retrying AC query: %s",                        (thd->query()) ? thd->query() : "void");  	  /* Performance Schema Interface instrumentation, end */  	  MYSQL_END_STATEMENT(thd->m_statement_psi, thd->get_stmt_da());  	  thd->m_statement_psi= NULL;            thd->m_digest= NULL; +	  // Released thd->LOCK_thd_data above as below could end up +	  // close_thread_tables()/close_open_tables()/close_thread_table()/mysql_mutex_lock(&thd->LOCK_thd_data)            close_thread_tables(thd); +	  mysql_mutex_lock(&thd->LOCK_thd_data);            thd->wsrep_conflict_state= RETRY_AUTOCOMMIT;            thd->wsrep_retry_counter++;            // grow            wsrep_copy_query(thd);            thd->set_time();            parser_state->reset(rawbuf, length); +          mysql_mutex_unlock(&thd->LOCK_thd_data);          }          else          { -          WSREP_DEBUG("%s, thd: %lld is_AC: %d, retry: %lu - %lu SQL: %s",  -                      (thd->wsrep_conflict_state == ABORTED) ?  +          mysql_mutex_unlock(&thd->LOCK_thd_data); +	  // This does dirty read to wsrep variables but it is only a debug code +          WSREP_DEBUG("%s, thd: %lld is_AC: %d, retry: %lu - %lu SQL: %s", +                      (thd->wsrep_conflict_state == ABORTED) ?                        "BF Aborted" : "cert failure",                        (longlong) thd->thread_id, is_autocommit, -                      thd->wsrep_retry_counter,  +                      thd->wsrep_retry_counter,                        thd->variables.wsrep_retry_autocommit, thd->query());            my_message(ER_LOCK_DEADLOCK, "Deadlock: wsrep aborted transaction",                       MYF(0)); + +	  mysql_mutex_lock(&thd->LOCK_thd_data);            thd->wsrep_conflict_state= NO_CONFLICT;            if (thd->wsrep_conflict_state != REPLAYING)              thd->wsrep_retry_counter= 0;             //  reset +	  mysql_mutex_unlock(&thd->LOCK_thd_data);          } -        mysql_mutex_unlock(&thd->LOCK_thd_data); +          thd->reset_killed();        }        else @@ -7891,6 +7904,7 @@ static void wsrep_mysql_parse(THD *thd, char *rawbuf, uint length,  #endif /* WITH_WSREP */  } +  /*    When you modify mysql_parse(), you may need to modify    mysql_test_parse_for_slave() in this same file. | 
