CacheManager | open source caching abstraction layer for .NET | Caching library
kandi X-RAY | CacheManager Summary
kandi X-RAY | CacheManager Summary
Supported framework targets changed since CacheManager 2.0. In case you have to target .NET 40 for example, you can still use CacheManager 1.x!.
Support
Quality
Security
License
Reuse
Top functions reviewed by kandi - BETA
Currently covering the most popular Java, JavaScript and Python libraries. See a Sample of CacheManager
CacheManager Key Features
CacheManager Examples and Code Snippets
Community Discussions
Trending Discussions on CacheManager
QUESTION
In my application I am using spring webflux and I am using webclient to retrieve details from some 3rd party API. Now, I want to store the first time webClient response in some in memory cache so that for 2nd time I can have those response directly from the cache. I am trying to use Spring boot in memory caching mechanism and also "caffine". But none is working as expected. application.yml:
...ANSWER
Answered 2022-Mar-19 at 23:46There are several options to cache reactive publishers.
- Use reactive
cache
API to cacheMono
for the defined duration
QUESTION
I have this issue in a Spring Boot microservices JHipster project, the issue started without changing any code. the microservers are deployed in a Kubernetes Microsoft Azure enviroment. The issue is related to a Hazelcast problem.
Stack trace:
...ANSWER
Answered 2021-Aug-06 at 16:25Two processes with the (default) cluster name dev
have found each other and attempted to cluster together. Versions are incompatible so this fails.
You could turn off discovery on both processes, but if you don't control the other this may not be viable.
Instead you could use config.getGroupConfig().setName('...')
to change the name of your cluster to prevent the join attempt.
QUESTION
We upgraded Hazelcast from 3.12.12
to 5.0.2
and now Spring cache doesn't preserve the order of the elements in the Map we store in the cache. It used to work before the upgrade. The java.util.TreeMap
we store in the cache is ordered using a custom java.util.Comparator
.
Below is the code. The getSortedCountriesFromCountryCodes()
method, when invoked, returns a Map whose elements are sorted correctly according to the custom comparator, but when the same map is retrieved from the cache, the order is lost and map items are ordered alphabetically using the corresponding keys. Spring version is 5.3.14
. Has anyone ever seen such behaviour and maybe knows how to fix it?
ANSWER
Answered 2022-Feb-21 at 18:53The issue is your MessageSourceComparator
, after deserialization it sorts differently.
There was a change how TreeMap is handled between 3.x and 4.x.
In 3.x the TreeMap is serialized using plain Java serialization. Apparently, it deserializes the data in the order it was stored in the map.
In 4.x+ a special serializer for TreeMap was added, what this serializer does on deserialization is that it creates new TreeSet with deserialized comparator and adds all elements to it. Now because your deserialized comparator is different the elements end up in the wrong order.
I don't think it is reasonable to expect to keep the order when the comparator changes on ser/de. What you can do is to cache LinkedHashMap instead:
QUESTION
I have a question about caching in spring using Caffeine.
I have a cache configuration:
...ANSWER
Answered 2022-Mar-02 at 13:39You can add multiple conditional @Cacheable
annotations to the @Caching
annotation.
QUESTION
Hello, Stackoverflow Community.
I have a Spring Boot application that uses Jcache with Hazelcast implementation as a cache Framework.
Each Hazelcast node has 5 caches with the size of 50000 elements each. There are 4 Hazelcast Instances that form a cluster.
The problem that I face is the following:
I have a very heavy call that reads data from all four caches. On the initial start, when all caches are yet empty, this call takes up to 600 seconds.
When there is one Hazelcast instance running and all 5 caches are filled with data, then this call happens relatively fast, it takes on average only 4 seconds.
When I start 2 Hazelcast instances and they form a cluster, then the response time gets worse, and the same call takes already 25 seconds on average.
And the more Hazelcast instances I add in a cluster, the longer the response time gets. Of course, I was expecting to see some worse delivery time when data is partitioned among Hazelcast nodes in a cluster. But I did not expect that just by adding one more hazelcast instance, the response time would get 6 - 7 times slower...
Please note, that for simplicity reasons and for testing purposes, I just start four Spring Boot Instances with each Hazelcast embedded node embedded in it on one machine. Therefore, such poor performance cannot be justified by network delays. I assume that this API call is so slow even with Hazelcast because much data needs to be serialized/deserialized when sent among Hazelcast cluster nodes. Please correct me if I am wrong.
The cache data is partitioned evenly among all nodes. I was thinking about adding near cache in order to reduce latency, however, according to the Hazelcast Documentation, the near cache is not available for Jcache Members. In my case, because of some project requirements, I am not able to switch to Jcache Clients to make use of Near Cache. Is there maybe some advice on how to reduce latency in such a scenario?
Thank you in advance.
DUMMY CODE SAMPLES TO DEMONSTRATE THE PROBLEM:
- Hazelcast Config: stays default, nothing is changed
- Caches:
ANSWER
Answered 2022-Feb-22 at 23:53If you do the math:
4s / 250 000 lookups is 0.016 ms per local lookup. This seems rather high, but let's take that.
When you add a single node then the data gets partitioned and half of the requests will be served from the other node. If you add 2 more nodes (4 total) then 25 % of the requests will be served locally and 75 % will be served over network. This should explain why the response time grows when you add more nodes.
Even simple ping on localhost takes twice or more time. On a real network the read latency we see in benchmarks is 0.3-0.4 ms per read call. This makes:
0.25 * 250k *0.016 + 0.75 * 250k * 0.3 = ~57 s
You simply won't be able to make so many calls serially over the network (even local one), you need to either
- parallelize the calls - use
javax.cache.Cache#getAll
to reduce the number of calls - you can try enabling reading local backups via
com.hazelcast.config.MapConfig#setReadBackupData
so there is less requests over the network.
The read backup data feature is only available for IMap, so you would need to use Spring caching with hazelcast-spring
module and its com.hazelcast.spring.cache.HazelcastCacheManager
:
QUESTION
Context -
I have a spring boot app and
I updated the spring-boot-starter-parent
version from 1.5.12.RELEASE
to 2.4.0
I had this dependency in my pom -
...ANSWER
Answered 2022-Feb-17 at 15:28With some more research over the web, I was able to fix the same exception which was occurring in my project by adding spring-context-support to the project.
I did it by adding following dependency to my build.gradle
:
QUESTION
I want to perform a background fetch and pass the result to closure. Currently I'm using performBackgroundTask
method from NSPersistentContainer
which is giving a NSManagedObjectContext
as a closure. Then using that context I'm executing fetch request. When fetch is done I'm, passing the result to the completion handler.
ANSWER
Answered 2022-Feb-13 at 03:16No, it is not
Do not pass NSManagedObject instances between queues. Doing so can result in corruption of the data and termination of the app. When it is necessary to hand off a managed object reference from one queue to another, use
NSManagedObjectID
instances.
You would want something like:
QUESTION
While implementing Hazelcast for the first time in set of web APIs, the usage of Map and Cache is inconsistent.
For example, creating a cache using SpringCacheManager results in the creation of a map
...ANSWER
Answered 2022-Jan-10 at 09:37There are Cache, Spring Cache and Map to consider here.
For Cache, Hazelcast is an implementation provider for the Java caching standard, JSR107.
These show as "Cache" on the Management Center, and if you run hazelcastInstance.getDistributedObjects()
they'll be of type ICache
. It's in the Hazelcast documentation here.
For Map, Hazelcast provides a data structure IMap
which is mostly a superset of java.util.Map
. These show as "Map" on the Management Center.
Spring also provides caching, and you can set CacheType for JSR107 or directly with Hazelcast, or allow Spring to pick. When Spring uses Hazelcast directly, it will use IMap
not ICache
for storage.
If you pick JCache or configure Spring to use JCache, then you get standards compliant behaviour. You have caching, and can easily swap caching provider from Hazelcast to something else should you want to.
Map gives you operations such as executeOnKey to update one or more entries in situ. If the entry is a compound object but on a small part is changing, this can be a more efficient way to update it than sending the whole value.
QUESTION
I am stuck with the dependency injection problem of NestJS during the unit test with jest. Here is my codebase. app.controller.spec.ts
ANSWER
Answered 2022-Jan-09 at 18:53You need to add the CACHE_MANAGER
as a provider to your TestingModule:
QUESTION
I added two service in Startup.cs as below,
...ANSWER
Answered 2021-Dec-29 at 13:49you have to follow one of the SOLID principles
The interface segregation principle: "Many client-specific interfaces are better than one general-purpose interface."
or
Community Discussions, Code Snippets contain sources that include Stack Exchange Network
Vulnerabilities
No vulnerabilities reported
Install CacheManager
Support
Reuse Trending Solutions
Find, review, and download reusable Libraries, Code Snippets, Cloud APIs from over 650 million Knowledge Items
Find more librariesStay Updated
Subscribe to our newsletter for trending solutions and developer bootcamps
Share this Page