diff options
author | Rich Prohaska <prohaska@tokutek.com> | 2014-11-21 16:32:08 -0500 |
---|---|---|
committer | Rich Prohaska <prohaska@tokutek.com> | 2014-11-21 16:32:08 -0500 |
commit | ebe25c6dfc859edb2a868a09bd4bf702bd73c7a5 (patch) | |
tree | ac3ab7a786f2985e217369d873596b9c762bbb19 | |
parent | 5d9a8276405792d623a3af15c0b433fc12349f93 (diff) | |
parent | b798b3546abb3247ed3500d712f65346b8b418ac (diff) | |
download | mariadb-git-ebe25c6dfc859edb2a868a09bd4bf702bd73c7a5.tar.gz |
Merge branch 'master' into releases/tokudb-7.5
-rw-r--r-- | storage/tokudb/hatoku_hton.cc | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/storage/tokudb/hatoku_hton.cc b/storage/tokudb/hatoku_hton.cc index 903d15c7969..438643d13d5 100644 --- a/storage/tokudb/hatoku_hton.cc +++ b/storage/tokudb/hatoku_hton.cc @@ -772,16 +772,31 @@ static void tokudb_cleanup_handlers(tokudb_trx_data *trx, DB_TXN *txn) { } } +#if MYSQL_VERSION_ID >= 50600 +extern "C" enum durability_properties thd_get_durability_property(const MYSQL_THD thd); +#endif + +// Determine if an fsync is used when a transaction is committed. The MySQL durability property +// has precedence over the tokudb commit sync setting as it has a better idea of what is going on. +static bool tokudb_fsync_on_commit(THD *thd) { +#if MYSQL_VERSION_ID >= 50600 + if (thd_get_durability_property(thd) == HA_IGNORE_DURABILITY) + return false; + else +#endif + return THDVAR(thd, commit_sync) != 0; +} + static int tokudb_commit(handlerton * hton, THD * thd, bool all) { TOKUDB_DBUG_ENTER(""); DBUG_PRINT("trans", ("ending transaction %s", all ? "all" : "stmt")); - uint32_t syncflag = THDVAR(thd, commit_sync) ? 0 : DB_TXN_NOSYNC; + uint32_t syncflag = tokudb_fsync_on_commit(thd) ? 0 : DB_TXN_NOSYNC; tokudb_trx_data *trx = (tokudb_trx_data *) thd_get_ha_data(thd, hton); DB_TXN **txn = all ? &trx->all : &trx->stmt; DB_TXN *this_txn = *txn; if (this_txn) { if (tokudb_debug & TOKUDB_DEBUG_TXN) { - TOKUDB_TRACE("commit trx %u txn %p", all, this_txn); + TOKUDB_TRACE("commit trx %u txn %p syncflag %u", all, this_txn, syncflag); } // test hook to induce a crash on a debug build DBUG_EXECUTE_IF("tokudb_crash_commit_before", DBUG_SUICIDE();); |