2013-04-17 00:02:06 -04:00
|
|
|
== Introduction ==
|
|
|
|
|
|
|
|
MySQL interfaces with TokuDB through a set of plugins, which, at
|
|
|
|
the time of this writing (October 2011) includes the tokudb storage
|
|
|
|
engine plugin, the user data information schema plugin, and the
|
2013-04-17 00:02:07 -04:00
|
|
|
user data exact information schema plugin. Each plugin provides
|
2013-04-17 00:02:06 -04:00
|
|
|
initialize and de-initialize functions for mysql to call when
|
2013-04-17 00:02:07 -04:00
|
|
|
they are installed or uninstalled by clients.
|
2013-04-17 00:02:06 -04:00
|
|
|
|
|
|
|
== Problem ==
|
|
|
|
|
|
|
|
It was originally discovered that the two information schema plugins
|
2013-04-17 00:02:07 -04:00
|
|
|
would crash if the tokudb storage engine failed to init properly. The
|
|
|
|
information plugins depend on the storage engine plugin, so a quick fix
|
|
|
|
for this problem was to have the storage engine plugin's init function
|
|
|
|
set a global flag if it failed. The information schema plugins could first
|
|
|
|
check this flag before proceeding. This fixed the original problem, but
|
|
|
|
the following still remain:
|
2013-04-17 00:02:06 -04:00
|
|
|
|
|
|
|
* a client connects, uninstalls tokudb storage engine, accesses
|
|
|
|
the tokudb user data/exact table.
|
|
|
|
|
|
|
|
* uninstall the tokudb engine plugin, drop a table, select from
|
|
|
|
it to see that it does not exist, then install the tokudb engine
|
|
|
|
to see that it has reappeared.
|
|
|
|
|
|
|
|
* any situation where one client is using any plugin while another
|
|
|
|
client modifies one.
|
|
|
|
|
|
|
|
== Proposed solution ==
|
|
|
|
|
2013-04-17 00:02:07 -04:00
|
|
|
Use a flag, call it tokudb_hton_initialized, that is set if the
|
|
|
|
storage engine's init function suceeds. The information schema plugins
|
|
|
|
will check that this flag is set before proceeding.
|
|
|
|
|
|
|
|
To protect against client race conditions, use a reader-writer lock to
|
|
|
|
protect the flag. Any clients which depend on the status of the flag
|
|
|
|
grab a read lock. Clients that change the status of the flag grab a write
|
|
|
|
lock. Using this flag and a protecting reader-writer lock, we can ensure
|
|
|
|
that no client is under the assumption that the handlerton is usable
|
|
|
|
while it is not, due to failure or uninstallation, etc.
|
2013-04-17 00:02:06 -04:00
|
|
|
|
|
|
|
== Implementation ==
|
|
|
|
|
2013-04-17 00:02:06 -04:00
|
|
|
{{{
|
2013-04-17 00:02:07 -04:00
|
|
|
#!c
|
2013-04-17 00:02:07 -04:00
|
|
|
|
|
|
|
static int tokudb_hton_initialized;
|
|
|
|
|
|
|
|
// grab a write lock when changing the
|
|
|
|
// hton_init flag
|
|
|
|
tokudb_hton_init_func() {
|
2013-04-17 00:02:06 -04:00
|
|
|
grab_hton_init_writelock();
|
|
|
|
...
|
|
|
|
tokudb_hton_initialized = 1;
|
|
|
|
error:
|
|
|
|
release_hton_init_writelock();
|
|
|
|
}
|
|
|
|
|
2013-04-17 00:02:07 -04:00
|
|
|
tokudb_hton_done_func() {
|
2013-04-17 00:02:06 -04:00
|
|
|
grab_hton_init_writelock();
|
|
|
|
...
|
|
|
|
tokudb_hton_initialized = 0;
|
|
|
|
release_hton_init_writelock();
|
|
|
|
}
|
|
|
|
|
2013-04-17 00:02:07 -04:00
|
|
|
// grab a read lock while assuming
|
|
|
|
// the handlerton is usable
|
|
|
|
//
|
|
|
|
// the user data init/done functions
|
|
|
|
// do not actually require this, but
|
|
|
|
// for sake of clarity we describe
|
|
|
|
// the algorithms as if they did.
|
|
|
|
// more importantly, the user data
|
|
|
|
// fill function DOES
|
|
|
|
tokudb_user_data_init_func() {
|
2013-04-17 00:02:06 -04:00
|
|
|
grab_hton_init_readlock();
|
|
|
|
...
|
|
|
|
release_hton_init_readlock();
|
|
|
|
}
|
|
|
|
|
2013-04-17 00:02:07 -04:00
|
|
|
tokudb_user_data_fill() {
|
2013-04-17 00:02:06 -04:00
|
|
|
grab_hton_init_readlock();
|
|
|
|
if (!tokudb_hton_initialized) {
|
2013-04-17 00:02:07 -04:00
|
|
|
goto error;
|
2013-04-17 00:02:06 -04:00
|
|
|
}
|
|
|
|
...
|
|
|
|
error:
|
|
|
|
release_hton_init_readlock();
|
|
|
|
}
|
|
|
|
|
2013-04-17 00:02:07 -04:00
|
|
|
tokudb_user_data_done_func() {
|
2013-04-17 00:02:06 -04:00
|
|
|
grab_hton_init_readlock();
|
|
|
|
...
|
|
|
|
release_hton_init_readlock();
|
|
|
|
}
|
2013-04-17 00:02:06 -04:00
|
|
|
}}}
|