Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement MemoryCache.Trim() to allow explicit removal #171

Open
judahr opened this issue Nov 27, 2021 · 0 comments
Open

Implement MemoryCache.Trim() to allow explicit removal #171

judahr opened this issue Nov 27, 2021 · 0 comments

Comments

@judahr
Copy link

judahr commented Nov 27, 2021

[Use the Thumbs Up reaction to vote for this feature, and please avoid adding comments like "+1" as they create noise for others watching the issue.]

Problem:
To remove expired items from the cache requires either explicitly doing it or requiring the system to execute a timer. A timer can be resource expensive. Keeping track of what needs to be removed duplicates the role of the cache expiration policy.

Solution 1:
Implementing the MemoryCache.Trim() function would be a nice in-between allowing a program to call a single method to trim the size of a possibly overgrown cache. This allows the underlying cache to perform the work with information it is already tracking. This would not be another ExpirationMode.

Solution 2:
Implement an explicit call that will tell the provider to go through and remove items that are expired. Rather than a timer, this can be called less frequently based on when the client application knows it is idle or has completed tasks. This would not be another ExpirationMode. It would simply expose to the client app what the ImmediateExpiration is already doing, but less frequently.

Background:
Iterating over data and caching expensive calculation results so later iterations can use it. Because the data and calculations are time series, the actual cache duration can be short and the application can perform a trim at intervals based on the data.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant