Skip to content

Commit

Permalink
Enhancements to rocksdb for better support for replication.
Browse files Browse the repository at this point in the history
Summary:
1. The OpenForReadOnly() call should not lock the db. This is useful
so that multiple processes can open the same database concurrently
for reading.
2. GetUpdatesSince should not error out if the archive directory
does not exist.
3. A new constructor for WriteBatch that can takes a serialized
string as a parameter of the constructor.

Test Plan: make clean check

Reviewers: sheki

Reviewed By: sheki

CC: leveldb

Differential Revision: https://reviews.facebook.net/D7449
  • Loading branch information
dhruba committed Dec 17, 2012
1 parent 62d4857 commit 3d1e92b
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 30 deletions.
7 changes: 1 addition & 6 deletions .arcconfig
Original file line number Diff line number Diff line change
@@ -1,10 +1,5 @@
{
"project_id" : "leveldb",
"conduit_uri" : "https://reviews.facebook.net/",
"copyright_holder" : "",
"load" : [
"linters/src/"
],
"lint_engine" : "FacebookFbcodeLintEngine",
"lint.engine.single.linter" : "FbcodeCppLinter"
"copyright_holder" : ""
}
47 changes: 26 additions & 21 deletions db/db_impl.cc
Original file line number Diff line number Diff line change
Expand Up @@ -512,31 +512,33 @@ Status DBImpl::Recover(VersionEdit* edit, bool no_log_recory,
// Ignore error from CreateDir since the creation of the DB is
// committed only when the descriptor is created, and this directory
// may already exist from a previous failed creation attempt.
env_->CreateDir(dbname_);
assert(db_lock_ == NULL);
Status s = env_->LockFile(LockFileName(dbname_), &db_lock_);
if (!s.ok()) {
return s;
}
if (!no_log_recory) {
env_->CreateDir(dbname_);
Status s = env_->LockFile(LockFileName(dbname_), &db_lock_);
if (!s.ok()) {
return s;
}

if (!env_->FileExists(CurrentFileName(dbname_))) {
if (options_.create_if_missing) {
s = NewDB();
if (!s.ok()) {
return s;
if (!env_->FileExists(CurrentFileName(dbname_))) {
if (options_.create_if_missing) {
s = NewDB();
if (!s.ok()) {
return s;
}
} else {
return Status::InvalidArgument(
dbname_, "does not exist (create_if_missing is false)");
}
} else {
return Status::InvalidArgument(
dbname_, "does not exist (create_if_missing is false)");
}
} else {
if (options_.error_if_exists) {
return Status::InvalidArgument(
dbname_, "exists (error_if_exists is true)");
if (options_.error_if_exists) {
return Status::InvalidArgument(
dbname_, "exists (error_if_exists is true)");
}
}
}

s = versions_->Recover();
Status s = versions_->Recover();
if (s.ok()) {
SequenceNumber max_sequence(0);

Expand Down Expand Up @@ -897,9 +899,12 @@ Status DBImpl::GetUpdatesSince(SequenceNumber seq,
return s;
}
// list wal files in archive dir.
s = ListAllWALFiles(ArchivalDirectory(dbname_), &walFiles, kArchivedLogFile);
if (!s.ok()) {
return s;
std::string archivedir = ArchivalDirectory(dbname_);
if (env_->FileExists(archivedir)) {
s = ListAllWALFiles(archivedir, &walFiles, kArchivedLogFile);
if (!s.ok()) {
return s;
}
}

if (walFiles.empty()) {
Expand Down
4 changes: 2 additions & 2 deletions db/transaction_log_iterator_impl.cc
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@ TransactionLogIteratorImpl::TransactionLogIteratorImpl(
isValid_(true),
currentFileIndex_(0),
currentLogReader_(NULL) {
assert( files_ != NULL);
}
assert( files_ != NULL);
}

LogReporter
TransactionLogIteratorImpl::NewLogReporter(const uint64_t logNumber) {
Expand Down
5 changes: 4 additions & 1 deletion include/leveldb/write_batch.h
Original file line number Diff line number Diff line change
Expand Up @@ -51,9 +51,12 @@ class WriteBatch {
};
Status Iterate(Handler* handler) const;

// Returns the serialized string
// Retrive the serialized version of this batch.
std::string Data() { return rep_; }

// Constructor with a serialized string object
WriteBatch(std::string rep): rep_(rep) {}

private:
friend class WriteBatchInternal;

Expand Down

0 comments on commit 3d1e92b

Please sign in to comment.