Commit 61e0b38f authored by unknown's avatar unknown

Restore some fixes for slow xtradb shutdown that were lost in the 5.5 merge.

parent 2573f03a
...@@ -2929,7 +2929,7 @@ srv_LRU_dump_restore_thread( ...@@ -2929,7 +2929,7 @@ srv_LRU_dump_restore_thread(
last_dump_time = time(NULL); last_dump_time = time(NULL);
loop: loop:
os_thread_sleep(5000000); os_event_wait_time_low(srv_shutdown_event, 5000000, 0);
if (srv_shutdown_state >= SRV_SHUTDOWN_CLEANUP) { if (srv_shutdown_state >= SRV_SHUTDOWN_CLEANUP) {
goto exit_func; goto exit_func;
...@@ -3240,9 +3240,11 @@ loop: ...@@ -3240,9 +3240,11 @@ loop:
/* Get sleep interval in micro seconds. We use /* Get sleep interval in micro seconds. We use
ut_min() to avoid long sleep in case of ut_min() to avoid long sleep in case of
wrap around. */ wrap around. */
os_thread_sleep(ut_min(1000000, os_event_wait_time_low(srv_shutdown_event,
(next_itr_time - cur_time) ut_min(1000000,
* 1000)); (next_itr_time - cur_time)
* 1000),
0);
srv_main_sleeps++; srv_main_sleeps++;
/* /*
...@@ -3835,6 +3837,7 @@ srv_purge_thread( ...@@ -3835,6 +3837,7 @@ srv_purge_thread(
ulint retries = 0; ulint retries = 0;
ulint n_total_purged = ULINT_UNDEFINED; ulint n_total_purged = ULINT_UNDEFINED;
ulint next_itr_time; ulint next_itr_time;
ib_int64_t sig_count;
ut_a(srv_n_purge_threads == 1); ut_a(srv_n_purge_threads == 1);
...@@ -3909,12 +3912,13 @@ srv_purge_thread( ...@@ -3909,12 +3912,13 @@ srv_purge_thread(
srv_sync_log_buffer_in_background(); srv_sync_log_buffer_in_background();
cur_time = ut_time_ms(); cur_time = ut_time_ms();
os_event_reset(srv_shutdown_event); sig_count = os_event_reset(srv_shutdown_event);
if (next_itr_time > cur_time) { if (next_itr_time > cur_time) {
os_event_wait_time(srv_shutdown_event, os_event_wait_time_low(srv_shutdown_event,
ut_min(1000000, ut_min(1000000,
(next_itr_time - cur_time) (next_itr_time - cur_time)
* 1000)); * 1000),
sig_count);
next_itr_time = ut_time_ms() + 1000; next_itr_time = ut_time_ms() + 1000;
} else { } else {
next_itr_time = cur_time + 1000; next_itr_time = cur_time + 1000;
......
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