Comments (4)
I'm not sure why get calls should always go to the slave. Usually slaves are used for replication and fail over. You can even setup the master to not store the data on disk and only the slave handles persistence. Not even sure if that would work with clusters at all?
Anyways, I don't really see a big need for that, but it could be implemented as a configuration option to override the defaults (which is master).
from cachemanager.
If the master is under heavy load, it would be nice to be reading also from the slaves nodes so we can free up some resources on master. I guess it depends on the size of the operation you are running but I can see the scenario
Actually vertical scaling depends on this
from cachemanager.
Just tested a few things. First of all, master to slave replication is non blocking async. So it could happen at any point that the items are not even on the slave although they just have been added.
Then, when retrieving an item, I also have to update e.g. sliding expiration. That can only happen on the master if the slave is readonly => doesn't work in one go (one lua script).
During update, I have to get the cache item to get the "old" value and then update to a new value. Those checks are pretty critical and shouldn't go on different servers.
=> will not be changed
from cachemanager.
All valid points, I didn´t think in the sliding expiration, but yes that should all happen in master. Although I think at least for items wtih absolute expiration or no expiration at all it could be implemented.
from cachemanager.
Related Issues (20)
- Json serializer does not support on redis? HOT 1
- Is it possible to do cache eviction when backplane is down HOT 1
- Cache manager locking threads HOT 2
- .Get() after .Add() or .AddOrUpdate fetches from Redis unexpectedly when using inProcessCache HOT 2
- Supporting .NET Standard 2.1 HOT 1
- Is CacheManager a dead project? HOT 1
- CacheManager.StackExchange.Redis add list type data problem
- How to get all the following data according to the prefix of the key
- Ocelot Cache - How do we Cache only success(200) response from micro services via API Gateway HOT 1
- Is there a plan to release a stable 2.x version ? HOT 1
- [Question] Using redis both for cache and for signalR HOT 1
- Changes in the object reflect in Cache without updating HOT 2
- Not possible to flush whole cache when using in-memory and redis handles HOT 2
- How to run AspnetCore.WebApp for NET 5.0? HOT 1
- Can we override config expiration settings during Add()? HOT 2
- Is this project still supported? HOT 3
- How to use SQL Server? HOT 1
- [Question] synchronize cache layer on application startup HOT 1
- New version / Nuget packages HOT 8
- How to 'add' item to all layers very first time HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from cachemanager.