Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 5943953
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 22, 20262026-05-22T16:28:08+00:00 2026-05-22T16:28:08+00:00

MemoryCache comes with a Default cache by default and additional named caches can be

  • 0

MemoryCache comes with a Default cache by default and additional named caches can be created.

It seems like there might be advantages to isolating the caching of results of different processes in different instances For example, results of queries against an index could be cached in an “IndexQueryResult” cache and result of database queries in a “DatabaseQueryResult” cache. That’s rather contrived but explains the principle.

Does the memory pressure on one cache that results in evictions affect the other caches at all? Are there any differences in the way .Net manages multiple caches compared to how it manages one?

Am I wasting my time considering the idea of multiple caches, or is there real value in doing so?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-22T16:28:09+00:00Added an answer on May 22, 2026 at 4:28 pm

    I can’t speak to the first few questions, and I’m interested to hear answers to those. However, I can say that we’ve been had a good experience so far using multiple caches in our product. Here are the benefits I see:

    • Reduced chance of key collision: Rather than coming up with some kind of scheme to ensure that no two separate values end up with the same key, we can simply create a cache that’s specific to a given repository type, and know that as long as that repository class uses keys unique to its objects, we won’t have collisions.
    • Better precision with cache eviction: The repository type that “owns” a particular cache instance can subscribe to certain event types on a system-wide event bus, so that it knows when some parts of the cache need to be purged. If we’re lucky, it can determine the keys of the entries to purge purely based on the arguments of the published event. However, this is often not the case, and we must either purge the entire cache or iterate through all the cached values to figure out which ones are affected by the published event. If we were using a single cache instance for all data types in our system, we would end up crawling through a lot of unrelated entries. By using separate caches, we can restrict our search to the values that this particular repository was responsible for populating.

    Regarding the second point: we also built a UI to expose all the cache instances in the system, and allow us to purge any of them with the click of a button. This comes in handy when we need to make changes directly to the database, and need the system to pick up those changes without having to restart the server. Again, if we only used a single cache, we couldn’t be nearly as precise: we’d have to purge all the cached values systemwide, instead of just the values associated with the data types that we tinkered with.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have created a cache using the MemoryCache class. I add some items to
I store an object in MemoryCache: void foo() { ObjectCache cache = MemoryCache.Default; SomeClass
Is there any library for distributed in-memory cache, distributed tasks, publish/subscribe messaging? I have
I would like to know if there is a way to have the .NET
Can we avoid casting T to Object when placing it in a Cache? WeakReference
I'm implementing a memory cache for a table that looks like this (simplified): Item1
the default asp.net in-memory cache mechanism ejects items from cache based on time. i
What are the best ways to keep data synchronized between in memory cache and
I'm planning to develop a web service, i need to use in memory cache,
Currently looking into distributed memory cache solutions, such as Memcached and Microsoft's AppFabric caching.

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.