tempDeleted items can use substantial proportion of bucket quota

Description

Due to a change in eviction behaviour in 7.1.0 ( https://review.couchbase.org/c/kv_engine/+/159487 ), we stopped removing tempDeleted values from the HashTable when the ExpiryPager ran.

This was done with a good reason: Pre-change, we would bump up expired item stats, which would then be misleading because these temp items are not user documents. The idea was to only clean them up by the ItemPager, when we hit the high watermark.

However, the unintended consequence is that we can get significant memory usage by tempDeleted items, which while benign (we can evict these), is misleading to the customer, who only sees that mem_used is growing. 

The proposed solution is to revert the old behaviour, clean up those items in the ExpiryPager (which runs every 10 mins by default), but to do so inline, without queuing them in the expired items list and without incrementing the expired item stats.

Note that technically, a frequently accessed tempDeleted item can have a higher value than a very cold valued item. In a sense, the old behaviour was closer to providing a globally optimal solution that reduces bg fetches. However, because memory usage by tempDeleted items is not directly observable, we'd like to avoid filling up the bucket quota with them.

Components

Fix versions

None

Labels

Environment

None

Link to Log File, atop/blg, CBCollectInfo, Core dump

None

Release Notes Description

None

Activity

Dave Rigby May 25, 2023 at 8:39 AM

Resolving as "Duplicate" - while that's not strictly accurate as it's a tangental issue triggered by the (now solved) solution, that's the closest resolution reason and I don't want to double-count this as a "fixed" bug in 7.1.5.

Dave Rigby May 25, 2023 at 8:34 AM

Note this issue is a consequence of the fix for . That issue has been addressed in a more targeted way via (go back to removing temp items via ExpiryPager, but don't count as expiries). As such, we can resolve this issue as "fixed" via .

Duplicate
Pinned fields
Click on the next to a field label to start pinning.

Details

Assignee

Reporter

Is this a Regression?

Yes

Triage

Untriaged

Due date

Story Points

Priority

Instabug

Open Instabug

PagerDuty

Sentry

Zendesk Support

Created May 22, 2023 at 10:58 AM
Updated September 19, 2024 at 10:23 AM
Resolved May 25, 2023 at 8:39 AM
Instabug