Commit 8a9d21b6 authored by unknown's avatar unknown

MDEV-4506: Parallel replication.

Do not update relay-log.info and master.info on disk after every event
when using GTID mode:

 - relay-log.info and master.info are not crash-safe, and are not used
   when slave restarts in GTID mode (slave connects with GTID position
   instead and immediately rewrites the file with the new, correct
   information found).

 - When using GTID and parallel replication, the position in
   relay-log.info is misleading at best and simply wrong at worst.

 - When using parallel replication, the fact that every single
   transaction needs to do a write() syscall to the same file is
   likely to become a serious bottleneck.

The files are still written at normal slave stop.

In non-GTID mode, the files are written as normal (this is needed to
be able to restart after slave crash, even if such restart is then not
crash-safe, no change).
parent 3e415fd1
...@@ -14,10 +14,7 @@ ...@@ -14,10 +14,7 @@
following transactions, so slave binlog position will be correct. following transactions, so slave binlog position will be correct.
And all the retry logic for temporary errors like deadlock. And all the retry logic for temporary errors like deadlock.
- In GTID replication, we should not need to update master.info and - Retry of failed transactions is not yet implemented for the parallel case.
relay-log.info on disk at all except at slave thread stop. They are not
used to know where to restart, the updates are not crash-safe, and it
could negatively affect performance.
- All the waits (eg. in struct wait_for_commit and in - All the waits (eg. in struct wait_for_commit and in
rpl_parallel_thread_pool::get_thread()) need to be killable. And on kill, rpl_parallel_thread_pool::get_thread()) need to be killable. And on kill,
...@@ -29,8 +26,6 @@ ...@@ -29,8 +26,6 @@
slave rolls back the transaction; parallel execution needs to be able slave rolls back the transaction; parallel execution needs to be able
to deal with this wrt. commit_orderer and such. to deal with this wrt. commit_orderer and such.
See Format_description_log_event::do_apply_event(). See Format_description_log_event::do_apply_event().
- Retry of failed transactions is not yet implemented for the parallel case.
*/ */
struct rpl_parallel_thread_pool global_rpl_thread_pool; struct rpl_parallel_thread_pool global_rpl_thread_pool;
......
...@@ -1274,9 +1274,12 @@ void Relay_log_info::stmt_done(my_off_t event_master_log_pos, ...@@ -1274,9 +1274,12 @@ void Relay_log_info::stmt_done(my_off_t event_master_log_pos,
DBA aware of the problem in the error log. DBA aware of the problem in the error log.
*/ */
} }
DBUG_EXECUTE_IF("inject_crash_before_flush_rli", DBUG_SUICIDE();); if (mi->using_gtid == Master_info::USE_GTID_NO)
flush_relay_log_info(this); {
DBUG_EXECUTE_IF("inject_crash_after_flush_rli", DBUG_SUICIDE();); DBUG_EXECUTE_IF("inject_crash_before_flush_rli", DBUG_SUICIDE(););
flush_relay_log_info(this);
DBUG_EXECUTE_IF("inject_crash_after_flush_rli", DBUG_SUICIDE(););
}
/* /*
Note that Rotate_log_event::do_apply_event() does not call this Note that Rotate_log_event::do_apply_event() does not call this
function, so there is no chance that a fake rotate event resets function, so there is no chance that a fake rotate event resets
......
...@@ -3901,7 +3901,8 @@ Stopping slave I/O thread due to out-of-memory error from master"); ...@@ -3901,7 +3901,8 @@ Stopping slave I/O thread due to out-of-memory error from master");
goto err; goto err;
} }
if (flush_master_info(mi, TRUE, TRUE)) if (mi->using_gtid != Master_info::USE_GTID_NO &&
flush_master_info(mi, TRUE, TRUE))
{ {
sql_print_error("Failed to flush master info file"); sql_print_error("Failed to flush master info file");
goto err; goto err;
...@@ -3978,6 +3979,8 @@ log space"); ...@@ -3978,6 +3979,8 @@ log space");
mi->mysql=0; mi->mysql=0;
} }
write_ignored_events_info_to_relay_log(thd, mi); write_ignored_events_info_to_relay_log(thd, mi);
if (mi->using_gtid != Master_info::USE_GTID_NO)
flush_master_info(mi, TRUE, TRUE);
thd_proc_info(thd, "Slave io thread waiting for slave mutex on exit"); thd_proc_info(thd, "Slave io thread waiting for slave mutex on exit");
mysql_mutex_lock(&mi->run_lock); mysql_mutex_lock(&mi->run_lock);
...@@ -4462,6 +4465,8 @@ the slave SQL thread with \"SLAVE START\". We stopped at log \ ...@@ -4462,6 +4465,8 @@ the slave SQL thread with \"SLAVE START\". We stopped at log \
thd->catalog= 0; thd->catalog= 0;
thd->reset_query(); thd->reset_query();
thd->reset_db(NULL, 0); thd->reset_db(NULL, 0);
if (rli->mi->using_gtid != Master_info::USE_GTID_NO)
flush_relay_log_info(rli);
thd_proc_info(thd, "Sql driver thread waiting for slave mutex on exit"); thd_proc_info(thd, "Sql driver thread waiting for slave mutex on exit");
mysql_mutex_lock(&rli->run_lock); mysql_mutex_lock(&rli->run_lock);
err_during_init: err_during_init:
......
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