Update blob db to use ROCKS_LOG_* macro
Summary: Update blob db to use the newer ROCKS_LOG_* macro. Closes https://github.com/facebook/rocksdb/pull/2574 Differential Revision: D5414526 Pulled By: yiwu-arbug fbshipit-source-id: e428753aa5917e8b435cead2db26df586e5d1def
This commit is contained in:
parent
43e4eef77f
commit
26ce69b195
@ -28,6 +28,7 @@
|
|||||||
#include "util/crc32c.h"
|
#include "util/crc32c.h"
|
||||||
#include "util/file_reader_writer.h"
|
#include "util/file_reader_writer.h"
|
||||||
#include "util/filename.h"
|
#include "util/filename.h"
|
||||||
|
#include "util/logging.h"
|
||||||
#include "util/random.h"
|
#include "util/random.h"
|
||||||
#include "util/timer_queue.h"
|
#include "util/timer_queue.h"
|
||||||
#include "utilities/transactions/optimistic_transaction_db_impl.h"
|
#include "utilities/transactions/optimistic_transaction_db_impl.h"
|
||||||
@ -174,9 +175,10 @@ void EvictAllVersionsCompactionListener::InternalListener::OnCompaction(
|
|||||||
Status s = handle.DecodeFrom(&lsmval);
|
Status s = handle.DecodeFrom(&lsmval);
|
||||||
if (s.ok()) {
|
if (s.ok()) {
|
||||||
if (impl_->debug_level_ >= 3)
|
if (impl_->debug_level_ >= 3)
|
||||||
Log(InfoLogLevel::INFO_LEVEL, impl_->db_options_.info_log,
|
ROCKS_LOG_INFO(impl_->db_options_.info_log,
|
||||||
"CALLBACK COMPACTED OUT KEY: %s SN: %d "
|
"CALLBACK COMPACTED OUT KEY: %s SN: %d "
|
||||||
"NEW: %d FN: %" PRIu64 " OFFSET: %" PRIu64 " SIZE: %" PRIu64,
|
"NEW: %d FN: %" PRIu64 " OFFSET: %" PRIu64
|
||||||
|
" SIZE: %" PRIu64,
|
||||||
key.ToString().c_str(), sn, is_new, handle.filenumber(),
|
key.ToString().c_str(), sn, is_new, handle.filenumber(),
|
||||||
handle.offset(), handle.size());
|
handle.offset(), handle.size());
|
||||||
|
|
||||||
@ -185,9 +187,9 @@ void EvictAllVersionsCompactionListener::InternalListener::OnCompaction(
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (impl_->debug_level_ >= 3)
|
if (impl_->debug_level_ >= 3)
|
||||||
Log(InfoLogLevel::INFO_LEVEL, impl_->db_options_.info_log,
|
ROCKS_LOG_INFO(impl_->db_options_.info_log,
|
||||||
"CALLBACK NEW KEY: %s SN: %d NEW: %d", key.ToString().c_str(), sn,
|
"CALLBACK NEW KEY: %s SN: %d NEW: %d",
|
||||||
is_new);
|
key.ToString().c_str(), sn, is_new);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -248,15 +250,15 @@ Status BlobDBImpl::LinkToBaseDB(DB* db) {
|
|||||||
|
|
||||||
Status s = myenv_->CreateDirIfMissing(blob_dir_);
|
Status s = myenv_->CreateDirIfMissing(blob_dir_);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(db_options_.info_log,
|
||||||
"Failed to create blob directory: %s status: '%s'", blob_dir_.c_str(),
|
"Failed to create blob directory: %s status: '%s'",
|
||||||
s.ToString().c_str());
|
blob_dir_.c_str(), s.ToString().c_str());
|
||||||
}
|
}
|
||||||
s = myenv_->NewDirectory(blob_dir_, &dir_ent_);
|
s = myenv_->NewDirectory(blob_dir_, &dir_ent_);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(db_options_.info_log,
|
||||||
"Failed to open blob directory: %s status: '%s'", blob_dir_.c_str(),
|
"Failed to open blob directory: %s status: '%s'",
|
||||||
s.ToString().c_str());
|
blob_dir_.c_str(), s.ToString().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!bdb_options_.disable_background_tasks) {
|
if (!bdb_options_.disable_background_tasks) {
|
||||||
@ -317,9 +319,9 @@ Status BlobDBImpl::OpenPhase1() {
|
|||||||
std::unique_ptr<Directory> dir_ent;
|
std::unique_ptr<Directory> dir_ent;
|
||||||
Status s = myenv_->NewDirectory(blob_dir_, &dir_ent);
|
Status s = myenv_->NewDirectory(blob_dir_, &dir_ent);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(db_options_.info_log,
|
||||||
"Failed to open blob directory: %s status: '%s'", blob_dir_.c_str(),
|
"Failed to open blob directory: %s status: '%s'",
|
||||||
s.ToString().c_str());
|
blob_dir_.c_str(), s.ToString().c_str());
|
||||||
open_p1_done_ = true;
|
open_p1_done_ = true;
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
@ -382,9 +384,9 @@ Status BlobDBImpl::GetAllLogFiles(
|
|||||||
if (psucc && type == kBlobFile) {
|
if (psucc && type == kBlobFile) {
|
||||||
file_nums->insert(std::make_pair(number, f));
|
file_nums->insert(std::make_pair(number, f));
|
||||||
} else {
|
} else {
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(db_options_.info_log,
|
||||||
"Skipping file in blob directory %s parse: %d type: %d", f.c_str(),
|
"Skipping file in blob directory %s parse: %d type: %d",
|
||||||
psucc, ((psucc) ? type : -1));
|
f.c_str(), psucc, ((psucc) ? type : -1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -398,14 +400,15 @@ Status BlobDBImpl::OpenAllFiles() {
|
|||||||
Status status = GetAllLogFiles(&file_nums);
|
Status status = GetAllLogFiles(&file_nums);
|
||||||
|
|
||||||
if (!status.ok()) {
|
if (!status.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to collect files from blob dir: %s status: '%s'",
|
"Failed to collect files from blob dir: %s status: '%s'",
|
||||||
blob_dir_.c_str(), status.ToString().c_str());
|
blob_dir_.c_str(), status.ToString().c_str());
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"BlobDir files path: %s count: %d min: %" PRIu64 " max: %" PRIu64,
|
"BlobDir files path: %s count: %d min: %" PRIu64
|
||||||
|
" max: %" PRIu64,
|
||||||
blob_dir_.c_str(), static_cast<int>(file_nums.size()),
|
blob_dir_.c_str(), static_cast<int>(file_nums.size()),
|
||||||
(file_nums.empty()) ? -1 : (file_nums.begin())->first,
|
(file_nums.empty()) ? -1 : (file_nums.begin())->first,
|
||||||
(file_nums.empty()) ? -1 : (file_nums.end())->first);
|
(file_nums.empty()) ? -1 : (file_nums.end())->first);
|
||||||
@ -418,15 +421,16 @@ Status BlobDBImpl::OpenAllFiles() {
|
|||||||
uint64_t size_bytes;
|
uint64_t size_bytes;
|
||||||
Status s1 = myenv_->GetFileSize(bfpath, &size_bytes);
|
Status s1 = myenv_->GetFileSize(bfpath, &size_bytes);
|
||||||
if (!s1.ok()) {
|
if (!s1.ok()) {
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(
|
||||||
|
db_options_.info_log,
|
||||||
"Unable to get size of %s. File skipped from open status: '%s'",
|
"Unable to get size of %s. File skipped from open status: '%s'",
|
||||||
bfpath.c_str(), s1.ToString().c_str());
|
bfpath.c_str(), s1.ToString().c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (debug_level_ >= 1)
|
if (debug_level_ >= 1)
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log, "Blob File open: %s size: %" PRIu64,
|
||||||
"Blob File open: %s size: %" PRIu64, bfpath.c_str(), size_bytes);
|
bfpath.c_str(), size_bytes);
|
||||||
|
|
||||||
std::shared_ptr<BlobFile> bfptr =
|
std::shared_ptr<BlobFile> bfptr =
|
||||||
std::make_shared<BlobFile>(this, blob_dir_, f_iter.first);
|
std::make_shared<BlobFile>(this, blob_dir_, f_iter.first);
|
||||||
@ -441,7 +445,7 @@ Status BlobDBImpl::OpenAllFiles() {
|
|||||||
reader = bfptr->OpenSequentialReader(myenv_, db_options_, env_options_);
|
reader = bfptr->OpenSequentialReader(myenv_, db_options_, env_options_);
|
||||||
s1 = reader->ReadHeader(&bfptr->header_);
|
s1 = reader->ReadHeader(&bfptr->header_);
|
||||||
if (!s1.ok()) {
|
if (!s1.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failure to read header for blob-file %s "
|
"Failure to read header for blob-file %s "
|
||||||
"status: '%s' size: %" PRIu64,
|
"status: '%s' size: %" PRIu64,
|
||||||
bfpath.c_str(), s1.ToString().c_str(), size_bytes);
|
bfpath.c_str(), s1.ToString().c_str(), size_bytes);
|
||||||
@ -459,14 +463,14 @@ Status BlobDBImpl::OpenAllFiles() {
|
|||||||
if (s1.ok()) {
|
if (s1.ok()) {
|
||||||
s1 = bfptr->SetFromFooterLocked(bf);
|
s1 = bfptr->SetFromFooterLocked(bf);
|
||||||
if (!s1.ok()) {
|
if (!s1.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Header Footer mismatch for blob-file %s "
|
"Header Footer mismatch for blob-file %s "
|
||||||
"status: '%s' size: %" PRIu64,
|
"status: '%s' size: %" PRIu64,
|
||||||
bfpath.c_str(), s1.ToString().c_str(), size_bytes);
|
bfpath.c_str(), s1.ToString().c_str(), size_bytes);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"File found incomplete (w/o footer) %s", bfpath.c_str());
|
"File found incomplete (w/o footer) %s", bfpath.c_str());
|
||||||
|
|
||||||
// sequentially iterate over the file and read all the records
|
// sequentially iterate over the file and read all the records
|
||||||
@ -496,15 +500,15 @@ Status BlobDBImpl::OpenAllFiles() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (record_start != bfptr->GetFileSize()) {
|
if (record_start != bfptr->GetFileSize()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Blob file is corrupted or crashed during write %s"
|
"Blob file is corrupted or crashed during write %s"
|
||||||
" good_size: %" PRIu64 " file_size: %" PRIu64,
|
" good_size: %" PRIu64 " file_size: %" PRIu64,
|
||||||
bfpath.c_str(), record_start, bfptr->GetFileSize());
|
bfpath.c_str(), record_start, bfptr->GetFileSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!blob_count) {
|
if (!blob_count) {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log, "BlobCount = 0 in file %s",
|
||||||
"BlobCount = 0 in file %s", bfpath.c_str());
|
bfpath.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -513,8 +517,9 @@ Status BlobDBImpl::OpenAllFiles() {
|
|||||||
|
|
||||||
if (bfptr->HasTimestamp()) bfptr->set_time_range(ts_range);
|
if (bfptr->HasTimestamp()) bfptr->set_time_range(ts_range);
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"Blob File: %s blob_count: %" PRIu64 " size_bytes: %" PRIu64
|
"Blob File: %s blob_count: %" PRIu64
|
||||||
|
" size_bytes: %" PRIu64
|
||||||
" sn_range: (%d, %d) ts: %d ttl: %d",
|
" sn_range: (%d, %d) ts: %d ttl: %d",
|
||||||
bfpath.c_str(), blob_count, size_bytes, sn_range.first,
|
bfpath.c_str(), blob_count, size_bytes, sn_range.first,
|
||||||
sn_range.second, bfptr->HasTimestamp(), bfptr->HasTTL());
|
sn_range.second, bfptr->HasTimestamp(), bfptr->HasTTL());
|
||||||
@ -531,14 +536,16 @@ Status BlobDBImpl::OpenAllFiles() {
|
|||||||
Status fstatus = CreateWriterLocked(bfptr);
|
Status fstatus = CreateWriterLocked(bfptr);
|
||||||
if (fstatus.ok()) fstatus = bfptr->WriteFooterAndCloseLocked();
|
if (fstatus.ok()) fstatus = bfptr->WriteFooterAndCloseLocked();
|
||||||
if (!fstatus.ok()) {
|
if (!fstatus.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(
|
||||||
|
db_options_.info_log,
|
||||||
"Failed to close Blob File: %s status: '%s'. Skipped",
|
"Failed to close Blob File: %s status: '%s'. Skipped",
|
||||||
bfpath.c_str(), fstatus.ToString().c_str());
|
bfpath.c_str(), fstatus.ToString().c_str());
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Blob File Closed: %s now: %d ttl_range: (%d, %d)",
|
"Blob File Closed: %s now: %d ttl_range: (%d, %d)",
|
||||||
bfpath.c_str(), epoch_now, ttl_range.first, ttl_range.second);
|
bfpath.c_str(), epoch_now, ttl_range.first,
|
||||||
|
ttl_range.second);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
open_blob_files_.insert(bfptr);
|
open_blob_files_.insert(bfptr);
|
||||||
@ -570,9 +577,8 @@ std::shared_ptr<RandomAccessFileReader> BlobDBImpl::GetOrOpenRandomAccessReader(
|
|||||||
std::shared_ptr<BlobFile> BlobDBImpl::NewBlobFile(const std::string& reason) {
|
std::shared_ptr<BlobFile> BlobDBImpl::NewBlobFile(const std::string& reason) {
|
||||||
uint64_t file_num = next_file_number_++;
|
uint64_t file_num = next_file_number_++;
|
||||||
auto bfile = std::make_shared<BlobFile>(this, blob_dir_, file_num);
|
auto bfile = std::make_shared<BlobFile>(this, blob_dir_, file_num);
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(db_options_.info_log, "New blob file created: %s reason='%s'",
|
||||||
"New blob file created: %s reason='%s'", bfile->PathName().c_str(),
|
bfile->PathName().c_str(), reason.c_str());
|
||||||
reason.c_str());
|
|
||||||
LogFlush(db_options_.info_log);
|
LogFlush(db_options_.info_log);
|
||||||
return bfile;
|
return bfile;
|
||||||
}
|
}
|
||||||
@ -588,7 +594,7 @@ Status BlobDBImpl::CreateWriterLocked(const std::shared_ptr<BlobFile>& bfile) {
|
|||||||
|
|
||||||
Status s = myenv_->ReopenWritableFile(fpath, &wfile, env_options);
|
Status s = myenv_->ReopenWritableFile(fpath, &wfile, env_options);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to open blob file for write: %s status: '%s'"
|
"Failed to open blob file for write: %s status: '%s'"
|
||||||
" exists: '%s'",
|
" exists: '%s'",
|
||||||
fpath.c_str(), s.ToString().c_str(),
|
fpath.c_str(), s.ToString().c_str(),
|
||||||
@ -601,8 +607,8 @@ Status BlobDBImpl::CreateWriterLocked(const std::shared_ptr<BlobFile>& bfile) {
|
|||||||
|
|
||||||
uint64_t boffset = bfile->GetFileSize();
|
uint64_t boffset = bfile->GetFileSize();
|
||||||
if (debug_level_ >= 2 && boffset) {
|
if (debug_level_ >= 2 && boffset) {
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(db_options_.info_log, "Open blob file: %s with offset: %d",
|
||||||
"Open blob file: %s with offset: %d", fpath.c_str(), boffset);
|
fpath.c_str(), boffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
Writer::ElemType et = Writer::kEtNone;
|
Writer::ElemType et = Writer::kEtNone;
|
||||||
@ -611,8 +617,9 @@ Status BlobDBImpl::CreateWriterLocked(const std::shared_ptr<BlobFile>& bfile) {
|
|||||||
else if (bfile->file_size_ > BlobLogHeader::kHeaderSize)
|
else if (bfile->file_size_ > BlobLogHeader::kHeaderSize)
|
||||||
et = Writer::kEtFooter;
|
et = Writer::kEtFooter;
|
||||||
else if (bfile->file_size_) {
|
else if (bfile->file_size_) {
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(db_options_.info_log,
|
||||||
"Open blob file: %s with wrong size: %d", fpath.c_str(), boffset);
|
"Open blob file: %s with wrong size: %d", fpath.c_str(),
|
||||||
|
boffset);
|
||||||
return Status::Corruption("Invalid blob file size");
|
return Status::Corruption("Invalid blob file size");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -687,8 +694,9 @@ std::shared_ptr<BlobFile> BlobDBImpl::SelectBlobFile() {
|
|||||||
// file not visible, hence no lock
|
// file not visible, hence no lock
|
||||||
std::shared_ptr<Writer> writer = CheckOrCreateWriterLocked(bfile);
|
std::shared_ptr<Writer> writer = CheckOrCreateWriterLocked(bfile);
|
||||||
if (!writer) {
|
if (!writer) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to get writer from blob file: %s", bfile->PathName().c_str());
|
"Failed to get writer from blob file: %s",
|
||||||
|
bfile->PathName().c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -704,7 +712,7 @@ std::shared_ptr<BlobFile> BlobDBImpl::SelectBlobFile() {
|
|||||||
|
|
||||||
Status s = writer->WriteHeader(bfile->header_);
|
Status s = writer->WriteHeader(bfile->header_);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to write header to new blob file: %s"
|
"Failed to write header to new blob file: %s"
|
||||||
" status: '%s'",
|
" status: '%s'",
|
||||||
bfile->PathName().c_str(), s.ToString().c_str());
|
bfile->PathName().c_str(), s.ToString().c_str());
|
||||||
@ -739,15 +747,14 @@ std::shared_ptr<BlobFile> BlobDBImpl::SelectBlobFileTTL(uint32_t expiration) {
|
|||||||
bfile = NewBlobFile("SelectBlobFileTTL");
|
bfile = NewBlobFile("SelectBlobFileTTL");
|
||||||
assert(bfile);
|
assert(bfile);
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log, "New blob file TTL range: %s %d %d",
|
||||||
"New blob file TTL range: %s %d %d", bfile->PathName().c_str(), exp_low,
|
bfile->PathName().c_str(), exp_low, exp_high);
|
||||||
exp_high);
|
|
||||||
LogFlush(db_options_.info_log);
|
LogFlush(db_options_.info_log);
|
||||||
|
|
||||||
// we don't need to take lock as no other thread is seeing bfile yet
|
// we don't need to take lock as no other thread is seeing bfile yet
|
||||||
std::shared_ptr<Writer> writer = CheckOrCreateWriterLocked(bfile);
|
std::shared_ptr<Writer> writer = CheckOrCreateWriterLocked(bfile);
|
||||||
if (!writer) {
|
if (!writer) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to get writer from blob file with TTL: %s",
|
"Failed to get writer from blob file with TTL: %s",
|
||||||
bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@ -772,7 +779,7 @@ std::shared_ptr<BlobFile> BlobDBImpl::SelectBlobFileTTL(uint32_t expiration) {
|
|||||||
|
|
||||||
Status s = writer->WriteHeader(bfile->header_);
|
Status s = writer->WriteHeader(bfile->header_);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to write header to new blob file: %s"
|
"Failed to write header to new blob file: %s"
|
||||||
" status: '%s'",
|
" status: '%s'",
|
||||||
bfile->PathName().c_str(), s.ToString().c_str());
|
bfile->PathName().c_str(), s.ToString().c_str());
|
||||||
@ -1047,18 +1054,19 @@ Status BlobDBImpl::PutUntil(const WriteOptions& options,
|
|||||||
// CheckOrCreateWriterLocked(bfile);
|
// CheckOrCreateWriterLocked(bfile);
|
||||||
|
|
||||||
if (debug_level_ >= 3)
|
if (debug_level_ >= 3)
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(
|
||||||
">Adding KEY FILE: %s: KEY: %s VALSZ: %d", bfile->PathName().c_str(),
|
db_options_.info_log, ">Adding KEY FILE: %s: KEY: %s VALSZ: %d",
|
||||||
key.ToString().c_str(), value.size());
|
bfile->PathName().c_str(), key.ToString().c_str(), value.size());
|
||||||
|
|
||||||
std::string index_entry;
|
std::string index_entry;
|
||||||
Status s = AppendBlob(bfile, headerbuf, key, value, &index_entry);
|
Status s = AppendBlob(bfile, headerbuf, key, value, &index_entry);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to append blob to FILE: %s: KEY: %s VALSZ: %d"
|
"Failed to append blob to FILE: %s: KEY: %s VALSZ: %d"
|
||||||
" status: '%s' blob_file: '%s'",
|
" status: '%s' blob_file: '%s'",
|
||||||
bfile->PathName().c_str(), key.ToString().c_str(), value.size(),
|
bfile->PathName().c_str(), key.ToString().c_str(),
|
||||||
s.ToString().c_str(), bfile->DumpState().c_str());
|
value.size(), s.ToString().c_str(),
|
||||||
|
bfile->DumpState().c_str());
|
||||||
// Fallback just write to the LSM and get going
|
// Fallback just write to the LSM and get going
|
||||||
WriteBatch batch;
|
WriteBatch batch;
|
||||||
batch.Put(column_family, key, value);
|
batch.Put(column_family, key, value);
|
||||||
@ -1075,17 +1083,17 @@ Status BlobDBImpl::PutUntil(const WriteOptions& options,
|
|||||||
SequenceNumber sn = WriteBatchInternal::Sequence(&batch);
|
SequenceNumber sn = WriteBatchInternal::Sequence(&batch);
|
||||||
|
|
||||||
if (debug_level_ >= 3)
|
if (debug_level_ >= 3)
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log, "<Adding KEY FILE: %s: KEY: %s SN: %d",
|
||||||
"<Adding KEY FILE: %s: KEY: %s SN: %d", bfile->PathName().c_str(),
|
bfile->PathName().c_str(), key.ToString().c_str(), sn);
|
||||||
key.ToString().c_str(), sn);
|
|
||||||
|
|
||||||
s = AppendSN(bfile, sn);
|
s = AppendSN(bfile, sn);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failed to append SN to FILE: %s: KEY: %s VALSZ: %d"
|
"Failed to append SN to FILE: %s: KEY: %s VALSZ: %d"
|
||||||
" status: '%s' blob_file: '%s'",
|
" status: '%s' blob_file: '%s'",
|
||||||
bfile->PathName().c_str(), key.ToString().c_str(), value.size(),
|
bfile->PathName().c_str(), key.ToString().c_str(),
|
||||||
s.ToString().c_str(), bfile->DumpState().c_str());
|
value.size(), s.ToString().c_str(),
|
||||||
|
bfile->DumpState().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (expiration != -1) extendTTL(&(bfile->ttl_range_), (uint32_t)expiration);
|
if (expiration != -1) extendTTL(&(bfile->ttl_range_), (uint32_t)expiration);
|
||||||
@ -1113,7 +1121,7 @@ Status BlobDBImpl::AppendBlob(const std::shared_ptr<BlobFile>& bfile,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Invalid status in AppendBlob: %s status: '%s'",
|
"Invalid status in AppendBlob: %s status: '%s'",
|
||||||
bfile->PathName().c_str(), s.ToString().c_str());
|
bfile->PathName().c_str(), s.ToString().c_str());
|
||||||
return s;
|
return s;
|
||||||
@ -1135,10 +1143,10 @@ Status BlobDBImpl::AppendBlob(const std::shared_ptr<BlobFile>& bfile,
|
|||||||
handle.EncodeTo(index_entry);
|
handle.EncodeTo(index_entry);
|
||||||
|
|
||||||
if (debug_level_ >= 3)
|
if (debug_level_ >= 3)
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
">Adding KEY FILE: %s: BC: %d OFFSET: %d SZ: %d",
|
">Adding KEY FILE: %s: BC: %d OFFSET: %d SZ: %d",
|
||||||
bfile->PathName().c_str(), bfile->blob_count_.load(), blob_offset,
|
bfile->PathName().c_str(), bfile->blob_count_.load(),
|
||||||
value.size());
|
blob_offset, value.size());
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
@ -1153,7 +1161,7 @@ Status BlobDBImpl::AppendSN(const std::shared_ptr<BlobFile>& bfile,
|
|||||||
|
|
||||||
s = writer->AddRecordFooter(sn);
|
s = writer->AddRecordFooter(sn);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Invalid status in AppendSN: %s status: '%s'",
|
"Invalid status in AppendSN: %s status: '%s'",
|
||||||
bfile->PathName().c_str(), s.ToString().c_str());
|
bfile->PathName().c_str(), s.ToString().c_str());
|
||||||
return s;
|
return s;
|
||||||
@ -1203,7 +1211,8 @@ Status BlobDBImpl::CommonGet(const ColumnFamilyData* cfd, const Slice& key,
|
|||||||
if (handle.offset() <
|
if (handle.offset() <
|
||||||
(BlobLogHeader::kHeaderSize + BlobLogRecord::kHeaderSize + key.size())) {
|
(BlobLogHeader::kHeaderSize + BlobLogRecord::kHeaderSize + key.size())) {
|
||||||
if (debug_level_ >= 2) {
|
if (debug_level_ >= 2) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(
|
||||||
|
db_options_.info_log,
|
||||||
"Invalid blob handle file_number: %" PRIu64 " blob_offset: %" PRIu64
|
"Invalid blob handle file_number: %" PRIu64 " blob_offset: %" PRIu64
|
||||||
" blob_size: %" PRIu64 " key: %s",
|
" blob_size: %" PRIu64 " key: %s",
|
||||||
handle.filenumber(), handle.offset(), handle.size(), key.data());
|
handle.filenumber(), handle.offset(), handle.size(), key.data());
|
||||||
@ -1254,7 +1263,8 @@ Status BlobDBImpl::CommonGet(const ColumnFamilyData* cfd, const Slice& key,
|
|||||||
s = reader->Read(handle.offset(), handle.size(), &blob_value, buffer);
|
s = reader->Read(handle.offset(), handle.size(), &blob_value, buffer);
|
||||||
if (!s.ok() || blob_value.size() != handle.size()) {
|
if (!s.ok() || blob_value.size() != handle.size()) {
|
||||||
if (debug_level_ >= 2) {
|
if (debug_level_ >= 2) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(
|
||||||
|
db_options_.info_log,
|
||||||
"Failed to read blob from file: %s blob_offset: %" PRIu64
|
"Failed to read blob from file: %s blob_offset: %" PRIu64
|
||||||
" blob_size: %" PRIu64 " read: %d key: %s status: '%s'",
|
" blob_size: %" PRIu64 " read: %d key: %s status: '%s'",
|
||||||
bfile->PathName().c_str(), handle.offset(), handle.size(),
|
bfile->PathName().c_str(), handle.offset(), handle.size(),
|
||||||
@ -1273,7 +1283,8 @@ Status BlobDBImpl::CommonGet(const ColumnFamilyData* cfd, const Slice& key,
|
|||||||
sizeof(uint32_t), &crc_slice, crc_buffer);
|
sizeof(uint32_t), &crc_slice, crc_buffer);
|
||||||
if (!s.ok() || !GetFixed32(&crc_slice, &crc_exp)) {
|
if (!s.ok() || !GetFixed32(&crc_slice, &crc_exp)) {
|
||||||
if (debug_level_ >= 2) {
|
if (debug_level_ >= 2) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(
|
||||||
|
db_options_.info_log,
|
||||||
"Failed to fetch blob crc file: %s blob_offset: %" PRIu64
|
"Failed to fetch blob crc file: %s blob_offset: %" PRIu64
|
||||||
" blob_size: %" PRIu64 " key: %s status: '%s'",
|
" blob_size: %" PRIu64 " key: %s status: '%s'",
|
||||||
bfile->PathName().c_str(), handle.offset(), handle.size(),
|
bfile->PathName().c_str(), handle.offset(), handle.size(),
|
||||||
@ -1286,11 +1297,11 @@ Status BlobDBImpl::CommonGet(const ColumnFamilyData* cfd, const Slice& key,
|
|||||||
crc = crc32c::Mask(crc); // Adjust for storage
|
crc = crc32c::Mask(crc); // Adjust for storage
|
||||||
if (crc != crc_exp) {
|
if (crc != crc_exp) {
|
||||||
if (debug_level_ >= 2) {
|
if (debug_level_ >= 2) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Blob crc mismatch file: %s blob_offset: %" PRIu64
|
"Blob crc mismatch file: %s blob_offset: %" PRIu64
|
||||||
" blob_size: %" PRIu64 " key: %s status: '%s'",
|
" blob_size: %" PRIu64 " key: %s status: '%s'",
|
||||||
bfile->PathName().c_str(), handle.offset(), handle.size(),
|
bfile->PathName().c_str(), handle.offset(),
|
||||||
key.data(), s.ToString().c_str());
|
handle.size(), key.data(), s.ToString().c_str());
|
||||||
}
|
}
|
||||||
return Status::Corruption("Corruption. Blob CRC mismatch");
|
return Status::Corruption("Corruption. Blob CRC mismatch");
|
||||||
}
|
}
|
||||||
@ -1335,9 +1346,9 @@ Status BlobDBImpl::Get(const ReadOptions& options,
|
|||||||
s = db_->Get(options, column_family, key, &index_entry);
|
s = db_->Get(options, column_family, key, &index_entry);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
if (debug_level_ >= 3)
|
if (debug_level_ >= 3)
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(db_options_.info_log,
|
||||||
"Get Failed on LSM KEY: %s status: '%s'", key.ToString().c_str(),
|
"Get Failed on LSM KEY: %s status: '%s'",
|
||||||
s.ToString().c_str());
|
key.ToString().c_str(), s.ToString().c_str());
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1360,13 +1371,13 @@ Slice BlobDBIterator::value() const {
|
|||||||
std::pair<bool, int64_t> BlobDBImpl::SanityCheck(bool aborted) {
|
std::pair<bool, int64_t> BlobDBImpl::SanityCheck(bool aborted) {
|
||||||
if (aborted) return std::make_pair(false, -1);
|
if (aborted) return std::make_pair(false, -1);
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log, "Starting Sanity Check");
|
ROCKS_LOG_INFO(db_options_.info_log, "Starting Sanity Check");
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log, "Number of files %" PRIu64,
|
||||||
"Number of files %" PRIu64, blob_files_.size());
|
blob_files_.size());
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log, "Number of open files %" PRIu64,
|
||||||
"Number of open files %" PRIu64, open_blob_files_.size());
|
open_blob_files_.size());
|
||||||
|
|
||||||
for (auto bfile : open_blob_files_) {
|
for (auto bfile : open_blob_files_) {
|
||||||
assert(!bfile->Immutable());
|
assert(!bfile->Immutable());
|
||||||
@ -1377,7 +1388,8 @@ std::pair<bool, int64_t> BlobDBImpl::SanityCheck(bool aborted) {
|
|||||||
|
|
||||||
for (auto bfile_pair : blob_files_) {
|
for (auto bfile_pair : blob_files_) {
|
||||||
auto bfile = bfile_pair.second;
|
auto bfile = bfile_pair.second;
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(
|
||||||
|
db_options_.info_log,
|
||||||
"Blob File %s %" PRIu64 " %" PRIu64 " %" PRIu64 " %" PRIu64 " %d",
|
"Blob File %s %" PRIu64 " %" PRIu64 " %" PRIu64 " %" PRIu64 " %d",
|
||||||
bfile->PathName().c_str(), bfile->GetFileSize(), bfile->BlobCount(),
|
bfile->PathName().c_str(), bfile->GetFileSize(), bfile->BlobCount(),
|
||||||
bfile->deleted_count_, bfile->deleted_size_,
|
bfile->deleted_count_, bfile->deleted_size_,
|
||||||
@ -1415,8 +1427,9 @@ void BlobDBImpl::CloseIf(const std::shared_ptr<BlobFile>& bfile) {
|
|||||||
if (!close) return;
|
if (!close) return;
|
||||||
|
|
||||||
if (debug_level_ >= 2) {
|
if (debug_level_ >= 2) {
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(db_options_.info_log,
|
||||||
"Scheduling file for close %s fsize: %" PRIu64 " limit: %" PRIu64,
|
"Scheduling file for close %s fsize: %" PRIu64
|
||||||
|
" limit: %" PRIu64,
|
||||||
bfile->PathName().c_str(), bfile->GetFileSize(),
|
bfile->PathName().c_str(), bfile->GetFileSize(),
|
||||||
bdb_options_.blob_file_size);
|
bdb_options_.blob_file_size);
|
||||||
}
|
}
|
||||||
@ -1430,7 +1443,7 @@ void BlobDBImpl::CloseIf(const std::shared_ptr<BlobFile>& bfile) {
|
|||||||
if (findit != open_simple_files_.end()) {
|
if (findit != open_simple_files_.end()) {
|
||||||
open_simple_files_.erase(findit);
|
open_simple_files_.erase(findit);
|
||||||
} else {
|
} else {
|
||||||
Log(InfoLogLevel::WARN_LEVEL, db_options_.info_log,
|
ROCKS_LOG_WARN(db_options_.info_log,
|
||||||
"File not found while closing %s fsize: %" PRIu64
|
"File not found while closing %s fsize: %" PRIu64
|
||||||
" Multithreaded Writes?",
|
" Multithreaded Writes?",
|
||||||
bfile->PathName().c_str(), bfile->GetFileSize());
|
bfile->PathName().c_str(), bfile->GetFileSize());
|
||||||
@ -1451,12 +1464,12 @@ bool BlobDBImpl::FileDeleteOk_SnapshotCheckLocked(
|
|||||||
// you want to check that there are no snapshots in the
|
// you want to check that there are no snapshots in the
|
||||||
bool notok = db_impl_->HasActiveSnapshotLaterThanSN(esn);
|
bool notok = db_impl_->HasActiveSnapshotLaterThanSN(esn);
|
||||||
if (notok) {
|
if (notok) {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"Could not delete file due to snapshot failure %s",
|
"Could not delete file due to snapshot failure %s",
|
||||||
bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"Will delete file due to snapshot success %s",
|
"Will delete file due to snapshot success %s",
|
||||||
bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
return true;
|
return true;
|
||||||
@ -1474,7 +1487,7 @@ bool BlobDBImpl::FindFileAndEvictABlob(uint64_t file_number, uint64_t key_size,
|
|||||||
|
|
||||||
// file was deleted
|
// file was deleted
|
||||||
if (hitr == blob_files_.end()) {
|
if (hitr == blob_files_.end()) {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"Could not find file_number %" PRIu64, file_number);
|
"Could not find file_number %" PRIu64, file_number);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -1495,7 +1508,7 @@ bool BlobDBImpl::MarkBlobDeleted(const Slice& key, const Slice& lsmValue) {
|
|||||||
BlobHandle handle;
|
BlobHandle handle;
|
||||||
Status s = handle.DecodeFrom(&val);
|
Status s = handle.DecodeFrom(&val);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"Could not parse lsm val in MarkBlobDeleted %s",
|
"Could not parse lsm val in MarkBlobDeleted %s",
|
||||||
lsmValue.ToString().c_str());
|
lsmValue.ToString().c_str());
|
||||||
return false;
|
return false;
|
||||||
@ -1514,13 +1527,15 @@ std::pair<bool, int64_t> BlobDBImpl::EvictCompacted(bool aborted) {
|
|||||||
packet.blob_offset_, packet.blob_size_);
|
packet.blob_offset_, packet.blob_size_);
|
||||||
|
|
||||||
if (!succ)
|
if (!succ)
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(
|
||||||
|
db_options_.info_log,
|
||||||
"EVICT COMPACTION FAILURE SN: %d FN: %d OFFSET: %d SIZE: %d",
|
"EVICT COMPACTION FAILURE SN: %d FN: %d OFFSET: %d SIZE: %d",
|
||||||
packet.dsn_, packet.file_number_, packet.blob_offset_,
|
packet.dsn_, packet.file_number_, packet.blob_offset_,
|
||||||
packet.blob_size_);
|
packet.blob_size_);
|
||||||
|
|
||||||
if (debug_level_ >= 3)
|
if (debug_level_ >= 3)
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(
|
||||||
|
db_options_.info_log,
|
||||||
"EVICT COMPACTED SN: %d FN: %d OFFSET: %d SIZE: %d SUCC: %d",
|
"EVICT COMPACTED SN: %d FN: %d OFFSET: %d SIZE: %d SUCC: %d",
|
||||||
packet.dsn_, packet.file_number_, packet.blob_offset_,
|
packet.dsn_, packet.file_number_, packet.blob_offset_,
|
||||||
packet.blob_size_, succ);
|
packet.blob_size_, succ);
|
||||||
@ -1565,8 +1580,8 @@ std::pair<bool, int64_t> BlobDBImpl::EvictDeletions(bool aborted) {
|
|||||||
iter->Seek(eslice);
|
iter->Seek(eslice);
|
||||||
|
|
||||||
if (!iter->status().ok()) {
|
if (!iter->status().ok()) {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log, "Invalid iterator seek %s",
|
||||||
"Invalid iterator seek %s", dpacket.key_.c_str());
|
dpacket.key_.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1714,7 +1729,7 @@ Status BlobDBImpl::GCFileAndUpdateLSM(const std::shared_ptr<BlobFile>& bfptr,
|
|||||||
std::shared_ptr<Reader> reader =
|
std::shared_ptr<Reader> reader =
|
||||||
bfptr->OpenSequentialReader(myenv_, db_options_, env_options_);
|
bfptr->OpenSequentialReader(myenv_, db_options_, env_options_);
|
||||||
if (!reader) {
|
if (!reader) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"File sequential reader could not be opened",
|
"File sequential reader could not be opened",
|
||||||
bfptr->PathName().c_str());
|
bfptr->PathName().c_str());
|
||||||
return Status::IOError("failed to create sequential reader");
|
return Status::IOError("failed to create sequential reader");
|
||||||
@ -1723,8 +1738,9 @@ Status BlobDBImpl::GCFileAndUpdateLSM(const std::shared_ptr<BlobFile>& bfptr,
|
|||||||
BlobLogHeader header;
|
BlobLogHeader header;
|
||||||
Status s = reader->ReadHeader(&header);
|
Status s = reader->ReadHeader(&header);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"Failure to read header for blob-file %s", bfptr->PathName().c_str());
|
"Failure to read header for blob-file %s",
|
||||||
|
bfptr->PathName().c_str());
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1798,11 +1814,12 @@ Status BlobDBImpl::GCFileAndUpdateLSM(const std::shared_ptr<BlobFile>& bfptr,
|
|||||||
// a new version of the key came in at this time, which will override
|
// a new version of the key came in at this time, which will override
|
||||||
// the current version being iterated on.
|
// the current version being iterated on.
|
||||||
if (s1.IsBusy()) {
|
if (s1.IsBusy()) {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"Optimistic transaction failed delete: %s bn: %" PRIu32,
|
"Optimistic transaction failed delete: %s bn: %" PRIu32,
|
||||||
bfptr->PathName().c_str(), gcstats->blob_count);
|
bfptr->PathName().c_str(), gcstats->blob_count);
|
||||||
} else {
|
} else {
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(
|
||||||
|
db_options_.info_log,
|
||||||
"Successfully added delete back into LSM: %s bn: %" PRIu32,
|
"Successfully added delete back into LSM: %s bn: %" PRIu32,
|
||||||
bfptr->PathName().c_str(), gcstats->blob_count);
|
bfptr->PathName().c_str(), gcstats->blob_count);
|
||||||
|
|
||||||
@ -1830,8 +1847,9 @@ Status BlobDBImpl::GCFileAndUpdateLSM(const std::shared_ptr<BlobFile>& bfptr,
|
|||||||
s = new_writer->WriteHeader(newfile->header_);
|
s = new_writer->WriteHeader(newfile->header_);
|
||||||
|
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"File: %s - header writing failed", newfile->PathName().c_str());
|
"File: %s - header writing failed",
|
||||||
|
newfile->PathName().c_str());
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1870,12 +1888,12 @@ Status BlobDBImpl::GCFileAndUpdateLSM(const std::shared_ptr<BlobFile>& bfptr,
|
|||||||
// a new version of the key came in at this time, which will override
|
// a new version of the key came in at this time, which will override
|
||||||
// the current version being iterated on.
|
// the current version being iterated on.
|
||||||
if (s1.IsBusy()) {
|
if (s1.IsBusy()) {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"Optimistic transaction failed: %s put bn: %" PRIu32,
|
"Optimistic transaction failed: %s put bn: %" PRIu32,
|
||||||
bfptr->PathName().c_str(), gcstats->blob_count);
|
bfptr->PathName().c_str(), gcstats->blob_count);
|
||||||
} else {
|
} else {
|
||||||
gcstats->succ_relocs++;
|
gcstats->succ_relocs++;
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(db_options_.info_log,
|
||||||
"Successfully added put back into LSM: %s bn: %" PRIu32,
|
"Successfully added put back into LSM: %s bn: %" PRIu32,
|
||||||
bfptr->PathName().c_str(), gcstats->blob_count);
|
bfptr->PathName().c_str(), gcstats->blob_count);
|
||||||
}
|
}
|
||||||
@ -1884,11 +1902,12 @@ Status BlobDBImpl::GCFileAndUpdateLSM(const std::shared_ptr<BlobFile>& bfptr,
|
|||||||
|
|
||||||
if (gcstats->newfile) total_blob_space_ += newfile->file_size_;
|
if (gcstats->newfile) total_blob_space_ += newfile->file_size_;
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"File: %s Num deletes %" PRIu32 " Num relocs: %" PRIu32
|
"File: %s Num deletes %" PRIu32 " Num relocs: %" PRIu32
|
||||||
" Succ Deletes: %" PRIu32 " Succ relocs: %" PRIu32,
|
" Succ Deletes: %" PRIu32 " Succ relocs: %" PRIu32,
|
||||||
bfptr->PathName().c_str(), gcstats->num_deletes, gcstats->num_relocs,
|
bfptr->PathName().c_str(), gcstats->num_deletes,
|
||||||
gcstats->succ_deletes_lsm, gcstats->succ_relocs);
|
gcstats->num_relocs, gcstats->succ_deletes_lsm,
|
||||||
|
gcstats->succ_relocs);
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
@ -1906,8 +1925,8 @@ bool BlobDBImpl::ShouldGCFile(std::shared_ptr<BlobFile> bfile, std::time_t tt,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!bfile->file_size_.load()) {
|
if (!bfile->file_size_.load()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log, "Invalid file size = 0 %s",
|
||||||
"Invalid file size = 0 %s", bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
*reason = "file is empty";
|
*reason = "file is empty";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -1990,7 +2009,7 @@ std::pair<bool, int64_t> BlobDBImpl::DeleteObsFiles(bool aborted) {
|
|||||||
|
|
||||||
Status s = myenv_->DeleteFile(bfile->PathName());
|
Status s = myenv_->DeleteFile(bfile->PathName());
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(db_options_.info_log,
|
||||||
"File failed to be deleted as obsolete %s",
|
"File failed to be deleted as obsolete %s",
|
||||||
bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
++iter;
|
++iter;
|
||||||
@ -1999,8 +2018,9 @@ std::pair<bool, int64_t> BlobDBImpl::DeleteObsFiles(bool aborted) {
|
|||||||
|
|
||||||
file_deleted = true;
|
file_deleted = true;
|
||||||
total_blob_space_ -= bfile->file_size_;
|
total_blob_space_ -= bfile->file_size_;
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"File deleted as obsolete from blob dir %s", bfile->PathName().c_str());
|
"File deleted as obsolete from blob dir %s",
|
||||||
|
bfile->PathName().c_str());
|
||||||
|
|
||||||
iter = tobsolete.erase(iter);
|
iter = tobsolete.erase(iter);
|
||||||
}
|
}
|
||||||
@ -2021,7 +2041,8 @@ bool BlobDBImpl::CallbackEvictsImpl(std::shared_ptr<BlobFile> bfile) {
|
|||||||
std::shared_ptr<Reader> reader =
|
std::shared_ptr<Reader> reader =
|
||||||
bfile->OpenSequentialReader(myenv_, db_options_, env_options_);
|
bfile->OpenSequentialReader(myenv_, db_options_, env_options_);
|
||||||
if (!reader) {
|
if (!reader) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(
|
||||||
|
db_options_.info_log,
|
||||||
"File sequential reader could not be opened for evict callback: %s",
|
"File sequential reader could not be opened for evict callback: %s",
|
||||||
bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
return false;
|
return false;
|
||||||
@ -2032,7 +2053,8 @@ bool BlobDBImpl::CallbackEvictsImpl(std::shared_ptr<BlobFile> bfile) {
|
|||||||
BlobLogHeader header;
|
BlobLogHeader header;
|
||||||
Status s = reader->ReadHeader(&header);
|
Status s = reader->ReadHeader(&header);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, db_options_.info_log,
|
ROCKS_LOG_ERROR(
|
||||||
|
db_options_.info_log,
|
||||||
"Failure to read header for blob-file during evict callback %s",
|
"Failure to read header for blob-file during evict callback %s",
|
||||||
bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
return false;
|
return false;
|
||||||
@ -2065,8 +2087,8 @@ std::pair<bool, int64_t> BlobDBImpl::CallbackEvicts(
|
|||||||
if (aborted) return std::make_pair(false, -1);
|
if (aborted) return std::make_pair(false, -1);
|
||||||
bool succ = CallbackEvictsImpl(bfile);
|
bool succ = CallbackEvictsImpl(bfile);
|
||||||
if (succ) {
|
if (succ) {
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(db_options_.info_log, "Eviction callbacks completed %s",
|
||||||
"Eviction callbacks completed %s", bfile->PathName().c_str());
|
bfile->PathName().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
WriteLock wl(&mutex_);
|
WriteLock wl(&mutex_);
|
||||||
@ -2129,14 +2151,14 @@ void BlobDBImpl::FilterSubsetOfFiles(
|
|||||||
std::string reason;
|
std::string reason;
|
||||||
bool shouldgc = ShouldGCFile(bfile, tt, last_id, &reason);
|
bool shouldgc = ShouldGCFile(bfile, tt, last_id, &reason);
|
||||||
if (!shouldgc) {
|
if (!shouldgc) {
|
||||||
Log(InfoLogLevel::DEBUG_LEVEL, db_options_.info_log,
|
ROCKS_LOG_DEBUG(db_options_.info_log,
|
||||||
"File has been skipped for GC ttl %s %d %d reason='%s'",
|
"File has been skipped for GC ttl %s %d %d reason='%s'",
|
||||||
bfile->PathName().c_str(), tt, bfile->GetTTLRange().second,
|
bfile->PathName().c_str(), tt,
|
||||||
reason.c_str());
|
bfile->GetTTLRange().second, reason.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
"File has been chosen for GC ttl %s %d %d reason='%s'",
|
"File has been chosen for GC ttl %s %d %d reason='%s'",
|
||||||
bfile->PathName().c_str(), tt, bfile->GetTTLRange().second,
|
bfile->PathName().c_str(), tt, bfile->GetTTLRange().second,
|
||||||
reason.c_str());
|
reason.c_str());
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include "utilities/blob_db/blob_db_impl.h"
|
#include "utilities/blob_db/blob_db_impl.h"
|
||||||
|
|
||||||
#include "util/filename.h"
|
#include "util/filename.h"
|
||||||
|
#include "util/logging.h"
|
||||||
|
|
||||||
namespace rocksdb {
|
namespace rocksdb {
|
||||||
|
|
||||||
@ -58,7 +59,7 @@ BlobFile::~BlobFile() {
|
|||||||
std::string pn(PathName());
|
std::string pn(PathName());
|
||||||
Status s = Env::Default()->DeleteFile(PathName());
|
Status s = Env::Default()->DeleteFile(PathName());
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
// Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log,
|
// ROCKS_LOG_INFO(db_options_.info_log,
|
||||||
// "File could not be deleted %s", pn.c_str());
|
// "File could not be deleted %s", pn.c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -110,7 +111,7 @@ bool BlobFile::NeedsFsync(bool hard, uint64_t bytes_per_sync) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Status BlobFile::WriteFooterAndCloseLocked() {
|
Status BlobFile::WriteFooterAndCloseLocked() {
|
||||||
Log(InfoLogLevel::INFO_LEVEL, parent_->db_options_.info_log,
|
ROCKS_LOG_INFO(parent_->db_options_.info_log,
|
||||||
"File is being closed after footer %s", PathName().c_str());
|
"File is being closed after footer %s", PathName().c_str());
|
||||||
|
|
||||||
BlobLogFooter footer;
|
BlobLogFooter footer;
|
||||||
@ -126,8 +127,9 @@ Status BlobFile::WriteFooterAndCloseLocked() {
|
|||||||
closed_ = true;
|
closed_ = true;
|
||||||
file_size_ += BlobLogFooter::kFooterSize;
|
file_size_ += BlobLogFooter::kFooterSize;
|
||||||
} else {
|
} else {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, parent_->db_options_.info_log,
|
ROCKS_LOG_ERROR(parent_->db_options_.info_log,
|
||||||
"Failure to read Header for blob-file %s", PathName().c_str());
|
"Failure to read Header for blob-file %s",
|
||||||
|
PathName().c_str());
|
||||||
}
|
}
|
||||||
// delete the sequential writer
|
// delete the sequential writer
|
||||||
log_writer_.reset();
|
log_writer_.reset();
|
||||||
@ -204,7 +206,7 @@ std::shared_ptr<RandomAccessFileReader> BlobFile::GetOrOpenRandomAccessReader(
|
|||||||
std::unique_ptr<RandomAccessFile> rfile;
|
std::unique_ptr<RandomAccessFile> rfile;
|
||||||
Status s = env->NewRandomAccessFile(PathName(), &rfile, env_options);
|
Status s = env->NewRandomAccessFile(PathName(), &rfile, env_options);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
Log(InfoLogLevel::ERROR_LEVEL, parent_->db_options_.info_log,
|
ROCKS_LOG_ERROR(parent_->db_options_.info_log,
|
||||||
"Failed to open blob file for random-read: %s status: '%s'"
|
"Failed to open blob file for random-read: %s status: '%s'"
|
||||||
" exists: '%s'",
|
" exists: '%s'",
|
||||||
PathName().c_str(), s.ToString().c_str(),
|
PathName().c_str(), s.ToString().c_str(),
|
||||||
|
Loading…
Reference in New Issue
Block a user