Don't call FindObsoleteFiles() in ~ColumnFamilyHandleImpl() if CF is not dropped (#5238)

Summary:
We have a DB with ~4k column families and ~70k files. On shutdown, destroying the 4k ColumnFamilyHandle-s takes over 2 minutes. Most of this time is spent in VersionSet::AddLiveFiles() called from FindObsoleteFiles() from ~ColumnFamilyHandleImpl(). It's just iterating over the list of files in memory. This seems completely unnecessary as no obsolete files are actually found since the CFs are not even dropped. This PR fixes that.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/5238

Differential Revision: D15056342

Pulled By: siying

fbshipit-source-id: 2aa342ef3770b4aa384ce81f8768e485480e4f08
This commit is contained in:
Mike Kolupaev 2019-04-24 17:07:31 -07:00 committed by Facebook Github Bot
parent aa56b7e74a
commit cd77d3c558

View File

@ -63,9 +63,14 @@ ColumnFamilyHandleImpl::~ColumnFamilyHandleImpl() {
JobContext job_context(0); JobContext job_context(0);
mutex_->Lock(); mutex_->Lock();
if (cfd_->Unref()) { if (cfd_->Unref()) {
bool dropped = cfd_->IsDropped();
delete cfd_; delete cfd_;
if (dropped) {
db_->FindObsoleteFiles(&job_context, false, true);
}
} }
db_->FindObsoleteFiles(&job_context, false, true);
mutex_->Unlock(); mutex_->Unlock();
if (job_context.HaveSomethingToDelete()) { if (job_context.HaveSomethingToDelete()) {
bool defer_purge = bool defer_purge =