Improve remove handling in cache

This commit is contained in:
Sebastian Messmer 2017-08-21 23:43:11 +01:00
parent 9d298bad6c
commit 30cec27bd8
2 changed files with 14 additions and 4 deletions

View File

@ -39,9 +39,8 @@ const Data& CachingBlockStore2::CachedBlock::read() const {
return _data; return _data;
} }
bool CachingBlockStore2::CachedBlock::remove() && { void CachingBlockStore2::CachedBlock::markNotDirty() && {
_dirty = false; // Prevent writing it back into the base store _dirty = false; // Prevent writing it back into the base store
return _blockStore->_baseBlockStore->remove(_key);
} }
void CachingBlockStore2::CachedBlock::write(Data data) { void CachingBlockStore2::CachedBlock::write(Data data) {
@ -72,7 +71,18 @@ bool CachingBlockStore2::remove(const Key &key) {
// TODO Don't write-through but cache remove operations // TODO Don't write-through but cache remove operations
auto popped = _cache.pop(key); auto popped = _cache.pop(key);
if (popped != boost::none) { if (popped != boost::none) {
std::move(**popped).remove(); // Remove from base store if it exists in the base store
{
unique_lock<mutex> lock(_cachedBlocksNotInBaseStoreMutex);
if (_cachedBlocksNotInBaseStore.count(key) == 0) {
const bool existedInBaseStore = _baseBlockStore->remove(key);
if (!existedInBaseStore) {
throw std::runtime_error("Tried to remove block. Block existed in cache and stated it exists in base store, but wasn't found there.");
}
}
}
// Don't write back the cached block when it is destructed
std::move(**popped).markNotDirty();
return true; return true;
} else { } else {
return _baseBlockStore->remove(key); return _baseBlockStore->remove(key);

View File

@ -32,7 +32,7 @@ private:
const cpputils::Data& read() const; const cpputils::Data& read() const;
void write(cpputils::Data data); void write(cpputils::Data data);
bool remove() &&; // only on rvalue because the destructor should be called after calling remove(). It shouldn't be put back into the cache. void markNotDirty() &&; // only on rvalue because the destructor should be called after calling markNotDirty(). It shouldn't be put back into the cache.
private: private:
const CachingBlockStore2* _blockStore; const CachingBlockStore2* _blockStore;
Key _key; Key _key;