ZiggyCreatures.FusionCache
2.2.0-preview-1
Prefix Reserved
See the version list below for details.
dotnet add package ZiggyCreatures.FusionCache --version 2.2.0-preview-1
NuGet\Install-Package ZiggyCreatures.FusionCache -Version 2.2.0-preview-1
<PackageReference Include="ZiggyCreatures.FusionCache" Version="2.2.0-preview-1" />
<PackageVersion Include="ZiggyCreatures.FusionCache" Version="2.2.0-preview-1" />
<PackageReference Include="ZiggyCreatures.FusionCache" />
paket add ZiggyCreatures.FusionCache --version 2.2.0-preview-1
#r "nuget: ZiggyCreatures.FusionCache, 2.2.0-preview-1"
#:package ZiggyCreatures.FusionCache@2.2.0-preview-1
#addin nuget:?package=ZiggyCreatures.FusionCache&version=2.2.0-preview-1&prerelease
#tool nuget:?package=ZiggyCreatures.FusionCache&version=2.2.0-preview-1&prerelease
FusionCache
FusionCache is an easy to use, fast and robust hybrid cache with advanced resiliency features.
It was born after years of dealing with all sorts of different types of caches: memory caching, distributed caching, http caching, CDNs, browser cache, offline cache, you name it.
So I tried to put together these experiences and came up with FusionCache.
Being a hybrid cache means it can transparently work as either a normal memory cache (L1) or as a multi-level cache (L1+L2), where the distributed 2nd level (L2) can be any implementation of the standard IDistributedCache
interface: this will get us better cold starts, better horizontal scalability, more resiliency and overall better performance.
FusionCache also includes an optional backplane for realtime sync between multiple nodes and advanced resiliency features like cache stampede protection, a fail-safe mechanism, soft/hard timeouts, eager refresh, full observability via logging and OpenTelemetry, tagging and much more.
It's being used in production on real-world projects with huge volumes for years, and is even used by Microsoft itself in its products like Data API Builder.
It's also compatible with the new HybridCache from Microsoft, thanks to a powerful integration.
๐ Award
On August 2021, FusionCache received the Google Open Source Peer Bonus Award: here is the official blogpost.
๐ Getting Started
With ๐ฆ A Gentle Introduction you'll get yourself comfortable with the overall concepts.
Want to start using it immediately? There's a โญ Quick Start for you.
Curious about what you can achieve from start to finish? There's a ๐ฉโ๐ซ Step By Step guide.
In search of all the docs? There's a page for that, too.
๐บ Media
More into videos?
I've been lucky enough to be invited on some shows and podcasts here and there: you can find them in the Media section.
A good example is when the fine folks at On .NET invited me on the show to allow me to mumbling random caching stuff.
โ Features
FusionCache has a lot of features, let's see them grouped together:
Resiliency
- ๐ก๏ธ Cache Stampede: automatic protection from the Cache Stampede problem
- ๐ฃ Fail-Safe: a mechanism to avoids transient failures, by reusing an expired entry as a temporary fallback
- โฉ๏ธ Auto-Recovery: self-healing for the entire cache, all automatically
Performance & Scalability
- ๐ L1+L2: any implementation of
IDistributedCache
can be used as an optional 2nd level, all transparently - ๐ข Backplane: in a multi-node scenario, it can notify the other nodes about changes in the cache, so all will be in-sync
- โฑ Soft/Hard Timeouts: a slow factory (or distributed cache) will not slow down your application, and no data will be wasted
- ๐ฆ Eager Refresh: start a non-blocking background refresh before the expiration occurs
- ๐ Conditional Refresh: like HTTP Conditional Requests, but for caching
- ๐ Background Distributed Operations: distributed operations can easily be executed in the background, safely, for better performance
Flexibility
- ๐ Named Caches: easily work with multiple named caches, even if differently configured
- ๐ท๏ธ Tagging: tags can be associated to entries, to later expire them all at once
- ๐งผ Clear: clear an entire cache, even with shared L2, cache key prefix, etc
- โ๏ธ Microsoft HybridCache: can be used as an implementation of the new HybridCache abstraction from Microsoft, all while adding extra features
- ๐งโโ๏ธ Adaptive Caching: for when you don't know upfront the entry options (eg:
Duration
), since they depends on the value being cached itself - ๐ Dependency Injection + Builder: native support for Dependency Injection, with a nice fluent interface including a Builder support
- โ Auto-Clone: be sure that cached values returned can be safely modified
- ๐ซ Fully sync/async: native support for both the synchronous and asynchronous programming model
- ๐งฉ Plugins: extend FusionCache with additional behavior like adding support for metrics, statistics, etc...
Observability
- ๐ญ OpenTelemetry: native observability support via OpenTelemetry
- ๐ Logging: comprehensive, structured and customizable, via the standard
ILogger
interface - ๐ Events: a comprehensive set of events, both at a high level and at lower levels (memory/distributed)
โญ Quick Start
Just install the ZiggyCreatures.FusionCache
Nuget package:
PM> Install-Package ZiggyCreatures.FusionCache
Then, let's say we have a method that loads a product from the database:
Product GetProductFromDb(int id) {
// DATABASE CALL HERE
}
(This is using the sync programming model, but it would be equally valid with the newer async one)
Then we create a FusionCache instance:
var cache = new FusionCache(new FusionCacheOptions());
or, if using dependency injection:
services.AddFusionCache();
Now, to get the product from the cache and, if not there, get it from the database in an optimized way and cache it for 30 sec
:
var id = 42;
cache.GetOrSet<Product>(
$"product:{id}",
_ => GetProductFromDb(id),
TimeSpan.FromSeconds(30)
);
That's it.
๐ฅ๏ธ Simulator
Distributed systems are, in general, quite complex to understand.
When using FusionCache with the distributed cache, the backplane and auto-recovery the Simulator can help us seeing the whole picture.
๐งฐ Supported Platforms
FusionCache targets .NET Standard 2.0
so any compatible .NET implementation is fine: this means .NET Framework
(the old one), .NET Core 2+
and .NET 5/6+
(the new ones), Mono
5.4+ and more (see here for a complete rundown).
NOTE: if you are running on .NET Framework 4.6.1 and want to use .NET Standard packages Microsoft suggests to upgrade to .NET Framework 4.7.2 or higher (see the .NET Standard Documentation) to avoid some known dependency issues.
๐ Comparison
There are various alternatives out there with different features, different performance characteristics (cpu/memory) and in general a different set of pros/cons.
A feature comparison between existing .NET caching solutions may help you choose which one to use.
๐ผ Is it Production Ready โข๏ธ ?
Yes!
FusionCache is being used in production on real world projects for years, happily handling billions of requests.
Considering that the FusionCache packages have been downloaded more than 14 million times (thanks everybody!) it may very well be used even more.
Oh, and it is being used in products by Microsoft itself, like Data API Builder!
๐ Are you using it?
If you find FusionCache useful please let me know, I'm interested in knowing your use case!
This is the only way for me to know how it is helping people.
๐ฐ Support
Nothing to do here.
After years of using a lot of open source stuff for free, this is just me trying to give something back to the community.
Will FusionCache one day switch to a commercial model? Nope, not gonna happen.
Mind you: nothing against other projects making the switch, if done in a proper way, but no thanks not interested. And FWIW I don't even accept donations, which are btw a great thing: that should tell you how much I'm into this for the money.
Again, this is me trying to give something back to the community.
If you really want to talk about money, please consider making ๐ฉท a donation to a good cause of your choosing, and let me know about that.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.0)
- System.Collections.Immutable (>= 9.0.0)
- System.Diagnostics.DiagnosticSource (>= 9.0.0)
- System.Threading.Tasks.Extensions (>= 4.6.0)
-
net8.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.0)
-
net9.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.0)
NuGet packages (42)
Showing the top 5 NuGet packages that depend on ZiggyCreatures.FusionCache:
Package | Downloads |
---|---|
ZiggyCreatures.FusionCache.Serialization.NewtonsoftJson
FusionCache serializer based on Newtonsoft Json.NET |
|
ZiggyCreatures.FusionCache.Backplane.StackExchangeRedis
FusionCache backplane for Redis based on the StackExchange.Redis library |
|
ZiggyCreatures.FusionCache.Serialization.SystemTextJson
FusionCache serializer based on System.Text.Json |
|
ZiggyCreatures.FusionCache.OpenTelemetry
Add native OpenTelemetry support to FusionCache. |
|
ZiggyCreatures.FusionCache.Chaos
Chaos-related utilities and implementations of various componenets (like a distributed cache or a backplane), useful for things like testing dependent components' behavior in a controlled failing environment. |
GitHub repositories (14)
Showing the top 14 popular GitHub repositories that depend on ZiggyCreatures.FusionCache:
Repository | Stars |
---|---|
Azure/data-api-builder
Data API builder provides modern REST and GraphQL endpoints to your Azure Databases and on-prem stores.
|
|
neozhu/CleanArchitectureWithBlazorServer
This is a repository for creating a Blazor Server dashboard application following the principles of Clean Architecture
|
|
VahidN/EFCoreSecondLevelCacheInterceptor
EF Core Second Level Cache Interceptor
|
|
TurnerSoftware/CacheTower
An efficient multi-layered caching system for .NET
|
|
YSGStudyHards/DotNetExercises
โใDotNetGuideไธๆ C#/.NET/.NET Core็ผ็จๆๅทง็ปไน ้ใC#/.NET/.NET Core็ผ็จๅธธ็จ่ฏญๆณใ็ฎๆณใๆๅทงใไธญ้ดไปถใ็ฑปๅบใๅทฅไฝไธๅกๅฎๆ็ปไน ้๏ผ้
ๅฅ่ฏฆ็ป็ๆ็ซ ๆ็จๅไปฃ็ ็คบไพ๏ผๅฉๅๅฟซ้ๆๆกC#/.NET/.NET Coreไธญๅ็ง็ผ็จๅธธ็จ่ฏญๆณใ็ฎๆณใๆๅทงใไธญ้ดไปถใ็ฑปๅบใๅทฅไฝไธๅกๅฎๆ็ญ็ญใ
|
|
LANCommander/LANCommander
|
|
JasonBock/Rocks
A mocking library based on the Compiler APIs (Roslyn + Mocks)
|
|
dotnet/dotnet-operator-sdk
KubeOps is a Kubernetes operator sdk in dotnet. Strongly inspired by kubebuilder.
|
|
ikyriak/IdempotentAPI
A .NET library that handles the HTTP write operations (POST and PATCH) that can affect only once for the given request data and idempotency-key by using an ASP.NET Core attribute (filter).
|
|
neozhu/cleanaspire
CleanAspire is a cloud-native template built on Aspire, using .NET 10 Minimal APIs and Blazor WebAssembly to deliver lightweight, scalable PWAs with offline support.
|
|
DamianMorozov/OpenTgResearcher
OpenTgResearcher - tool for analyzing Telegram chats and downloading their content
|
|
dr-marek-jaskula/DomainDrivenDesignUniversity
This project was made for tutorial purpose - to clearly present the domain driven design concept.
|
|
neon-sunset/fast-cache
The fastest cache library written in C# for items with set expiration time. Easy to use, thread-safe and light on memory.
|
|
ncosentino/DevLeader
Projects referred to by my blog, Dev Leader
|
Version | Downloads | Last Updated | |
---|---|---|---|
2.4.0 | 525,952 | 8/17/2025 | |
2.3.0 | 858,955 | 6/9/2025 | |
2.2.0 | 686,469 | 4/18/2025 | |
2.2.0-preview-1 | 3,277 | 4/6/2025 | |
2.1.0 | 1,174,480 | 2/2/2025 | |
2.0.2 | 72,811 | 4/18/2025 | |
2.0.1 | 87,599 | 2/23/2025 | |
2.0.0 | 251,110 | 1/19/2025 | |
2.0.0-preview-4 | 5,081 | 1/1/2025 | |
2.0.0-preview-3 | 25,728 | 12/9/2024 | |
2.0.0-preview-2 | 3,120 | 11/14/2024 | |
2.0.0-preview-1 | 1,766 | 11/10/2024 | |
1.4.1 | 1,231,757 | 10/27/2024 | |
1.4.0 | 865,866 | 9/15/2024 | |
1.3.0 | 1,839,629 | 8/4/2024 | |
1.2.0 | 540,029 | 6/2/2024 | |
1.2.0-preview1 | 1,196 | 5/19/2024 | |
1.1.0 | 351,589 | 4/24/2024 | |
1.0.0 | 456,853 | 2/29/2024 | |
1.0.0-preview2 | 5,076 | 2/23/2024 | |
1.0.0-preview1 | 1,561 | 2/11/2024 | |
0.26.0 | 201,562 | 2/11/2024 | |
0.25.0 | 48,307 | 2/4/2024 | |
0.25.0-preview1 | 1,809 | 1/14/2024 | |
0.24.0 | 490,406 | 11/12/2023 | |
0.24.0-preview1 | 2,210 | 9/3/2023 | |
0.23.0 | 730,774 | 8/1/2023 | |
0.22.0 | 149,320 | 7/9/2023 | |
0.21.0 | 954,259 | 5/28/2023 | |
0.21.0-preview2 | 2,082 | 5/21/2023 | |
0.21.0-preview1 | 2,100 | 5/1/2023 | |
0.20.0 | 222,294 | 4/8/2023 | |
0.20.0-preview2 | 1,990 | 3/29/2023 | |
0.20.0-preview1 | 2,253 | 3/3/2023 | |
0.19.0 | 214,157 | 2/12/2023 | |
0.18.0 | 157,084 | 12/18/2022 | |
0.17.0 | 59,758 | 12/4/2022 | |
0.16.0 | 62,157 | 11/12/2022 | |
0.15.0 | 272,800 | 10/26/2022 | |
0.14.0 | 52,458 | 10/18/2022 | |
0.13.0 | 170,685 | 8/14/2022 | |
0.12.0 | 49,175 | 7/19/2022 | |
0.11.1 | 43,185 | 7/15/2022 | |
0.11.0 | 43,304 | 7/12/2022 | |
0.10.0 | 212,703 | 5/1/2022 | |
0.10.0-preview1 | 1,888 | 4/23/2022 | |
0.9.0 | 114,060 | 2/17/2022 | |
0.1.10-beta3 | 3,621 | 2/14/2022 | |
0.1.10-beta2 | 1,928 | 2/11/2022 | |
0.1.10-beta1 | 1,849 | 2/9/2022 | |
0.1.10-alpha2 | 1,936 | 1/30/2022 | |
0.1.10-alpha1 | 1,752 | 1/27/2022 | |
0.1.9 | 95,416 | 11/23/2021 | |
0.1.8 | 47,575 | 11/23/2021 | |
0.1.7 | 61,740 | 10/16/2021 | |
0.1.6 | 76,904 | 8/1/2021 | |
0.1.5 | 47,454 | 6/29/2021 | |
0.1.4 | 44,916 | 6/5/2021 | |
0.1.3 | 44,496 | 4/3/2021 | |
0.1.2 | 55,109 | 2/26/2021 | |
0.1.1 | 43,069 | 1/19/2021 | |
0.1.0 | 58,790 | 12/31/2020 |
- Change: updated multi-targeting to be more slim and to include only the currently supported versions
- Add: make the AOT support official
- Add: expose the current distributed cache, if any
- Add: expose the current backplane, if any
- Add NullFusionCache support via DI
- Add: new memory locker based on the 3rd party AsyncKeyedLock library
- Perf: better perf for Clear(true) when Raw Clear is possible (eg: L1 only)
- Change: more async usage with the backplane (less thread blocking)
- Change: better, more differentiated log levels
- Change: no more distributed cache errors in the logs when used internally, only warnings
- Fix: fixed a bug with Eager Refresh in high concurrency scenarios
- Fix: fixed a small bug happening when using jittering and fail-safe
- Update: package dependencies