Commit 6f1f9114 authored by Vladislav Vaintroub's avatar Vladislav Vaintroub

MDEV-12445 : Rocksdb does not shutdown worker threads and aborts in memleak...

MDEV-12445 : Rocksdb does not shutdown worker threads and aborts in memleak check on server shutdown

Disable memory leak check in debug server, if rocksdb is loaded.
There is some subtle bug somewhere in 3rd party code we cannot
do much about.

The bug is manifested as follows

Rocksdb does not shutdown worker threads, when plugin is shut down. Thus
OS does not unload the library since there are some active threads using
this library's code. Thus global destructors in the library do not run,
and there is still some memory allocated when server exits.

The workaround disables server's memory leak check, if rocksdb engine was
loaded.
parent 53d6325d
...@@ -365,6 +365,7 @@ static bool volatile select_thread_in_use, signal_thread_in_use; ...@@ -365,6 +365,7 @@ static bool volatile select_thread_in_use, signal_thread_in_use;
static volatile bool ready_to_exit; static volatile bool ready_to_exit;
static my_bool opt_debugging= 0, opt_external_locking= 0, opt_console= 0; static my_bool opt_debugging= 0, opt_external_locking= 0, opt_console= 0;
static my_bool opt_short_log_format= 0, opt_silent_startup= 0; static my_bool opt_short_log_format= 0, opt_silent_startup= 0;
bool my_disable_leak_check= false;
uint kill_cached_threads; uint kill_cached_threads;
static uint wake_thread; static uint wake_thread;
...@@ -2155,7 +2156,7 @@ static void mysqld_exit(int exit_code) ...@@ -2155,7 +2156,7 @@ static void mysqld_exit(int exit_code)
shutdown_performance_schema(); // we do it as late as possible shutdown_performance_schema(); // we do it as late as possible
#endif #endif
set_malloc_size_cb(NULL); set_malloc_size_cb(NULL);
if (!opt_debugging) if (!opt_debugging && !my_disable_leak_check)
{ {
DBUG_ASSERT(global_status_var.global_memory_used == 0); DBUG_ASSERT(global_status_var.global_memory_used == 0);
} }
......
...@@ -97,6 +97,8 @@ int thd_binlog_format(const MYSQL_THD thd); ...@@ -97,6 +97,8 @@ int thd_binlog_format(const MYSQL_THD thd);
bool thd_binlog_filter_ok(const MYSQL_THD thd); bool thd_binlog_filter_ok(const MYSQL_THD thd);
} }
MYSQL_PLUGIN_IMPORT bool my_disable_leak_check;
namespace myrocks { namespace myrocks {
static st_global_stats global_stats; static st_global_stats global_stats;
...@@ -3593,6 +3595,14 @@ static int rocksdb_init_func(void *const p) { ...@@ -3593,6 +3595,14 @@ static int rocksdb_init_func(void *const p) {
#endif #endif
sql_print_information("RocksDB instance opened"); sql_print_information("RocksDB instance opened");
/**
Rocksdb does not always shutdown its threads, when
plugin is shut down. Disable server's leak check
at exit to avoid crash.
*/
my_disable_leak_check = true;
DBUG_RETURN(HA_EXIT_SUCCESS); DBUG_RETURN(HA_EXIT_SUCCESS);
} }
......
...@@ -60,7 +60,6 @@ rocksdb_deadlock_stress_rr: stress test ...@@ -60,7 +60,6 @@ rocksdb_deadlock_stress_rr: stress test
# MDEV-12474 Regularly failing tests on Buildbot # MDEV-12474 Regularly failing tests on Buildbot
autoinc_vars_thread : MDEV-12474 Regularly fails on buildbot autoinc_vars_thread : MDEV-12474 Regularly fails on buildbot
validate_datadic : MDEV-12474 Regularly fails on buildbot
unique_check : MDEV-12474 Regularly fails on buildbot unique_check : MDEV-12474 Regularly fails on buildbot
bloomfilter : MDEV-12474 Regularly fails on buildbot bloomfilter : MDEV-12474 Regularly fails on buildbot
......
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