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:
Yi Wu 2017-07-13 10:03:39 -07:00 committed by Facebook Github Bot
parent 43e4eef77f
commit 26ce69b195
2 changed files with 225 additions and 201 deletions

View File

@ -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());

View File

@ -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(),