Cleaning up BackupableDB + fix valgrind errors

Summary: Valgrind complained about BackupableDB. This fixes valgrind errors. Also, I cleaned up some code.

Test Plan: valgrind does not complain anymore

Reviewers: dhruba

Reviewed By: dhruba

CC: leveldb

Differential Revision: https://reviews.facebook.net/D14529
main
Igor Canadi 11 years ago
parent 0e2c966f58
commit 7cf5728440
  1. 40
      utilities/backupable/backupable_db.cc
  2. 14
      utilities/backupable/backupable_db_test.cc

@ -82,6 +82,8 @@ class BackupEngine {
std::vector<std::string> files_; std::vector<std::string> files_;
std::unordered_map<std::string, int>* file_refs_; std::unordered_map<std::string, int>* file_refs_;
Env* env_; Env* env_;
static const size_t max_backup_meta_file_size_ = 10 * 1024 * 1024; // 10MB
}; // BackupMeta }; // BackupMeta
inline std::string GetAbsolutePath( inline std::string GetAbsolutePath(
@ -144,8 +146,6 @@ class BackupEngine {
Env* db_env_; Env* db_env_;
Env* backup_env_; Env* backup_env_;
// constants
static const size_t max_backup_meta_file_size_ = 10 * 1024 * 1024; // 10MB
static const size_t copy_file_buffer_size_ = 5 * 1024 * 1024LL; // 5MB static const size_t copy_file_buffer_size_ = 5 * 1024 * 1024LL; // 5MB
}; };
@ -438,21 +438,19 @@ Status BackupEngine::GetLatestBackupFileContents(uint32_t* latest_backup) {
return s; return s;
} }
char* buf = new char[10]; char buf[11];
Slice data(buf, 0); Slice data;
s = file->Read(10, &data, buf); s = file->Read(10, &data, buf);
if (!s.ok() || data.size() == 0) { if (!s.ok() || data.size() == 0) {
delete[] buf;
return s.ok() ? Status::Corruption("Latest backup file corrupted") : s; return s.ok() ? Status::Corruption("Latest backup file corrupted") : s;
} }
buf[data.size()] = 0;
*latest_backup = 0;
sscanf(data.data(), "%u", latest_backup); sscanf(data.data(), "%u", latest_backup);
if (backup_env_->FileExists(GetBackupMetaFile(*latest_backup)) == false) { if (backup_env_->FileExists(GetBackupMetaFile(*latest_backup)) == false) {
s = Status::Corruption("Latest backup file corrupted"); s = Status::Corruption("Latest backup file corrupted");
} }
delete[] buf;
return Status::OK(); return Status::OK();
} }
@ -473,7 +471,7 @@ Status BackupEngine::PutLatestBackupFileContents(uint32_t latest_backup) {
return s; return s;
} }
char* file_contents = new char[10]; char file_contents[10];
int len = sprintf(file_contents, "%u\n", latest_backup); int len = sprintf(file_contents, "%u\n", latest_backup);
s = file->Append(Slice(file_contents, len)); s = file->Append(Slice(file_contents, len));
if (s.ok() && options_.sync) { if (s.ok() && options_.sync) {
@ -519,13 +517,13 @@ Status BackupEngine::CopyFile(const std::string& src,
return s; return s;
} }
char* buf = new char[copy_file_buffer_size_]; unique_ptr<char[]> buf(new char[copy_file_buffer_size_]);
Slice data(buf, 0); Slice data;
do { do {
size_t buffer_to_read = (copy_file_buffer_size_ < size_limit) ? size_t buffer_to_read = (copy_file_buffer_size_ < size_limit) ?
copy_file_buffer_size_ : size_limit; copy_file_buffer_size_ : size_limit;
s = src_file->Read(buffer_to_read, &data, buf); s = src_file->Read(buffer_to_read, &data, buf.get());
size_limit -= data.size(); size_limit -= data.size();
if (size != nullptr) { if (size != nullptr) {
*size += data.size(); *size += data.size();
@ -700,12 +698,11 @@ Status BackupEngine::BackupMeta::LoadFromFile(const std::string& backup_dir) {
return s; return s;
} }
char* buf = new char[max_backup_meta_file_size_ + 1]; unique_ptr<char[]> buf(new char[max_backup_meta_file_size_ + 1]);
Slice data(buf, 0); Slice data;
s = backup_meta_file->Read(max_backup_meta_file_size_, &data, buf); s = backup_meta_file->Read(max_backup_meta_file_size_, &data, buf.get());
if (!s.ok() || data.size() == max_backup_meta_file_size_) { if (!s.ok() || data.size() == max_backup_meta_file_size_) {
delete[] buf;
return s.ok() ? Status::IOError("File size too big") : s; return s.ok() ? Status::IOError("File size too big") : s;
} }
buf[data.size()] = 0; buf[data.size()] = 0;
@ -724,7 +721,6 @@ Status BackupEngine::BackupMeta::LoadFromFile(const std::string& backup_dir) {
AddFile(filename, size); AddFile(filename, size);
} }
delete[] buf;
return s; return s;
} }
@ -739,15 +735,15 @@ Status BackupEngine::BackupMeta::StoreToFile(bool sync) {
return s; return s;
} }
char* buf = new char[max_backup_meta_file_size_]; unique_ptr<char[]> buf(new char[max_backup_meta_file_size_]);
int len = 0, buf_size = max_backup_meta_file_size_; int len = 0, buf_size = max_backup_meta_file_size_;
len += snprintf(buf, buf_size, "%" PRId64 "\n", timestamp_); len += snprintf(buf.get(), buf_size, "%" PRId64 "\n", timestamp_);
len += snprintf(buf + len, buf_size - len, "%zu\n", files_.size()); len += snprintf(buf.get() + len, buf_size - len, "%zu\n", files_.size());
for (size_t i = 0; i < files_.size(); ++i) { for (size_t i = 0; i < files_.size(); ++i) {
len += snprintf(buf + len, buf_size - len, "%s\n", files_[i].c_str()); len += snprintf(buf.get() + len, buf_size - len, "%s\n", files_[i].c_str());
} }
s = backup_meta_file->Append(Slice(buf, (size_t)len)); s = backup_meta_file->Append(Slice(buf.get(), (size_t)len));
if (s.ok() && sync) { if (s.ok() && sync) {
s = backup_meta_file->Sync(); s = backup_meta_file->Sync();
} }

@ -124,8 +124,13 @@ class TestEnv : public EnvWrapper {
explicit TestEnv(Env* t) : EnvWrapper(t) {} explicit TestEnv(Env* t) : EnvWrapper(t) {}
class DummySequentialFile : public SequentialFile { class DummySequentialFile : public SequentialFile {
public:
DummySequentialFile() : SequentialFile(), rnd_(5) {}
virtual Status Read(size_t n, Slice* result, char* scratch) { virtual Status Read(size_t n, Slice* result, char* scratch) {
size_t read_size = (n > size_left) ? size_left : n; size_t read_size = (n > size_left) ? size_left : n;
for (size_t i = 0; i < read_size; ++i) {
scratch[i] = rnd_.Next() & 255;
}
*result = Slice(scratch, read_size); *result = Slice(scratch, read_size);
size_left -= read_size; size_left -= read_size;
return Status::OK(); return Status::OK();
@ -137,6 +142,7 @@ class TestEnv : public EnvWrapper {
} }
private: private:
size_t size_left = 200; size_t size_left = 200;
Random rnd_;
}; };
Status NewSequentialFile(const std::string& f, Status NewSequentialFile(const std::string& f,
@ -291,9 +297,9 @@ class BackupableDBTest {
options_.wal_dir = dbname_; options_.wal_dir = dbname_;
// set up backup db options // set up backup db options
CreateLoggerFromOptions(dbname_, backupdir_, env_, CreateLoggerFromOptions(dbname_, backupdir_, env_,
Options(), &logger); Options(), &logger_);
backupable_options_.reset(new BackupableDBOptions( backupable_options_.reset(new BackupableDBOptions(
backupdir_, test_backup_env_.get(), logger.get(), true)); backupdir_, test_backup_env_.get(), logger_.get(), true));
// delete old files in db // delete old files in db
DestroyDB(dbname_, Options()); DestroyDB(dbname_, Options());
@ -377,7 +383,7 @@ class BackupableDBTest {
// options // options
Options options_; Options options_;
unique_ptr<BackupableDBOptions> backupable_options_; unique_ptr<BackupableDBOptions> backupable_options_;
std::shared_ptr<Logger> logger; std::shared_ptr<Logger> logger_;
}; // BackupableDBTest }; // BackupableDBTest
void AppendPath(const std::string& path, std::vector<std::string>& v) { void AppendPath(const std::string& path, std::vector<std::string>& v) {
@ -432,6 +438,8 @@ TEST(BackupableDBTest, NoDoubleCopy) {
ASSERT_EQ(100, size); ASSERT_EQ(100, size);
test_backup_env_->GetFileSize(backupdir_ + "/shared/00015.sst", &size); test_backup_env_->GetFileSize(backupdir_ + "/shared/00015.sst", &size);
ASSERT_EQ(200, size); ASSERT_EQ(200, size);
CloseBackupableDB();
} }
// test various kind of corruptions that may happen: // test various kind of corruptions that may happen:

Loading…
Cancel
Save