mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-11 17:02:25 +00:00
Fix
This commit is contained in:
parent
9b74e246af
commit
607a9d761b
@ -67,11 +67,11 @@ void EvictionCandidates::removeQueueEntries(const CachePriorityGuard::Lock & loc
|
|||||||
{
|
{
|
||||||
for (const auto & candidate : key_candidates.candidates)
|
for (const auto & candidate : key_candidates.candidates)
|
||||||
{
|
{
|
||||||
const auto & file_segment = candidate->file_segment;
|
auto queue_iterator = candidate->getQueueIterator();
|
||||||
auto file_segment_lock = file_segment->lock();
|
queue_iterator->invalidate();
|
||||||
|
|
||||||
candidate->getQueueIterator()->remove(lock);
|
candidate->file_segment->resetQueueIterator();
|
||||||
file_segment->setQueueIteratorUnlocked(nullptr, file_segment_lock);
|
queue_iterator->remove(lock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
removed_queue_entries = true;
|
removed_queue_entries = true;
|
||||||
@ -101,10 +101,14 @@ void EvictionCandidates::evict()
|
|||||||
{
|
{
|
||||||
auto & candidate = key_candidates.candidates.back();
|
auto & candidate = key_candidates.candidates.back();
|
||||||
chassert(candidate->releasable());
|
chassert(candidate->releasable());
|
||||||
|
|
||||||
const auto segment = candidate->file_segment;
|
const auto segment = candidate->file_segment;
|
||||||
auto iterator = segment->getQueueIterator();
|
|
||||||
chassert(iterator);
|
IFileCachePriority::IteratorPtr iterator;
|
||||||
|
if (!removed_queue_entries)
|
||||||
|
{
|
||||||
|
iterator = segment->getQueueIterator();
|
||||||
|
chassert(iterator);
|
||||||
|
}
|
||||||
|
|
||||||
ProfileEvents::increment(ProfileEvents::FilesystemCacheEvictedFileSegments);
|
ProfileEvents::increment(ProfileEvents::FilesystemCacheEvictedFileSegments);
|
||||||
ProfileEvents::increment(ProfileEvents::FilesystemCacheEvictedBytes, segment->range().size());
|
ProfileEvents::increment(ProfileEvents::FilesystemCacheEvictedBytes, segment->range().size());
|
||||||
@ -133,7 +137,7 @@ void EvictionCandidates::evict()
|
|||||||
/// it was freed in favour of some reserver, so we can make it visibly
|
/// it was freed in favour of some reserver, so we can make it visibly
|
||||||
/// free only for that particular reserver.
|
/// free only for that particular reserver.
|
||||||
|
|
||||||
if (!removed_queue_entries)
|
if (iterator)
|
||||||
queue_entries_to_invalidate.push_back(iterator);
|
queue_entries_to_invalidate.push_back(iterator);
|
||||||
|
|
||||||
key_candidates.candidates.pop_back();
|
key_candidates.candidates.pop_back();
|
||||||
|
Loading…
Reference in New Issue
Block a user