Commit 25c0f032 authored by John Esmet's avatar John Esmet Committed by Yoni Fogel

fixes #5278 fixes #5329 use an autoincrement open id for txnless environments...

fixes #5278 fixes #5329 use an autoincrement open id for txnless environments and optionally create a txn for change_descriptor by using an autotxn


git-svn-id: file:///svn/toku/tokudb@46475 c7de825b-a66e-492c-adef-691d508d4ae1
parent 60216f66
...@@ -203,6 +203,8 @@ db_open_subdb(DB * db, DB_TXN * txn, const char *fname, const char *dbname, DBTY ...@@ -203,6 +203,8 @@ db_open_subdb(DB * db, DB_TXN * txn, const char *fname, const char *dbname, DBTY
return r; return r;
} }
static uint64_t nontransactional_open_id = 0;
// inames are created here. // inames are created here.
// algorithm: // algorithm:
// begin txn // begin txn
...@@ -272,6 +274,8 @@ toku_db_open(DB * db, DB_TXN * txn, const char *fname, const char *dbname, DBTYP ...@@ -272,6 +274,8 @@ toku_db_open(DB * db, DB_TXN * txn, const char *fname, const char *dbname, DBTYP
if (txn) { if (txn) {
id = toku_txn_get_txnid(db_txn_struct_i(txn)->tokutxn); id = toku_txn_get_txnid(db_txn_struct_i(txn)->tokutxn);
} else {
id = __sync_fetch_and_add(&nontransactional_open_id, 1);
} }
create_iname_hint(dname, hint); create_iname_hint(dname, hint);
iname = create_iname(db->dbenv, id, hint, NULL, -1); // allocated memory for iname iname = create_iname(db->dbenv, id, hint, NULL, -1); // allocated memory for iname
...@@ -722,13 +726,23 @@ locked_db_open(DB *db, DB_TXN *txn, const char *fname, const char *dbname, DBTYP ...@@ -722,13 +726,23 @@ locked_db_open(DB *db, DB_TXN *txn, const char *fname, const char *dbname, DBTYP
} }
static int static int
locked_db_change_descriptor(DB *db, DB_TXN* txn, const DBT* descriptor, uint32_t flags) { locked_db_change_descriptor(DB *db, DB_TXN *txn, const DBT *descriptor, uint32_t flags) {
toku_multi_operation_client_lock(); //Cannot begin checkpoint // cannot begin a checkpoint
toku_multi_operation_client_lock();
int r = toku_db_change_descriptor(db, txn, descriptor, flags); int r = toku_db_change_descriptor(db, txn, descriptor, flags);
toku_multi_operation_client_unlock(); //Can now begin checkpoint toku_multi_operation_client_unlock();
return r; return r;
} }
static int
autotxn_db_change_descriptor(DB *db, DB_TXN *txn, const DBT *descriptor, uint32_t flags) {
bool changed; int r;
r = toku_db_construct_autotxn(db, &txn, &changed, false);
if (r != 0) { return r; }
r = locked_db_change_descriptor(db, txn, descriptor, flags);
return toku_db_destruct_autotxn(txn, r, changed);
}
static void static void
toku_db_set_errfile (DB *db, FILE *errfile) { toku_db_set_errfile (DB *db, FILE *errfile) {
db->dbenv->set_errfile(db->dbenv, errfile); db->dbenv->set_errfile(db->dbenv, errfile);
...@@ -887,7 +901,6 @@ toku_db_create(DB ** db, DB_ENV * env, uint32_t flags) { ...@@ -887,7 +901,6 @@ toku_db_create(DB ** db, DB_ENV * env, uint32_t flags) {
#define SDB(name) result->name = locked_db_ ## name #define SDB(name) result->name = locked_db_ ## name
SDB(close); SDB(close);
SDB(open); SDB(open);
SDB(change_descriptor);
SDB(optimize); SDB(optimize);
#undef SDB #undef SDB
// methods that do not take the ydb lock // methods that do not take the ydb lock
...@@ -923,6 +936,7 @@ toku_db_create(DB ** db, DB_ENV * env, uint32_t flags) { ...@@ -923,6 +936,7 @@ toku_db_create(DB ** db, DB_ENV * env, uint32_t flags) {
result->put = autotxn_db_put; result->put = autotxn_db_put;
result->update = autotxn_db_update; result->update = autotxn_db_update;
result->update_broadcast = autotxn_db_update_broadcast; result->update_broadcast = autotxn_db_update_broadcast;
result->change_descriptor = autotxn_db_change_descriptor;
// unlocked methods // unlocked methods
result->get = autotxn_db_get; result->get = autotxn_db_get;
......
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