ZiggyCreatures.FusionCache 1.3.0

FusionCache

FusionCache logo

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've tried to put together these experiences and came up with FusionCache.

FusionCache diagram

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 and much more.

🏆 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.

On .NET Talk

✔ Features

These are the key features of FusionCache:

⭐ Quick Start

FusionCache can be installed via the nuget UI (search for the ZiggyCreatures.FusionCache package) or via the nuget package manager console:

PM> Install-Package ZiggyCreatures.FusionCache

As an example, imagine having a method that retrieves a product from your database:

Product GetProductFromDb(int id) {
	// YOUR DATABASE CALL HERE
}

💡 This is using the sync programming model, but it would be equally valid with the newer async one for even better performance.

To start using FusionCache the first thing is create a cache instance:

var cache = new FusionCache(new FusionCacheOptions());

If instead you are using DI (Dependency Injection) use this:

services.AddFusionCache();

We can also specify some global options, like a default FusionCacheEntryOptions object to serve as a default for each call we'll make, with a duration of 2 minutes and a Low priority:

var cache = new FusionCache(new FusionCacheOptions() {
	DefaultEntryOptions = new FusionCacheEntryOptions {
		Duration = TimeSpan.FromMinutes(2),
		Priority = CacheItemPriority.Low
	}
});

Or, using DI, like this:

services.AddFusionCache()
	.WithDefaultEntryOptions(new FusionCacheEntryOptions {
		Duration = TimeSpan.FromMinutes(2),
		Priority = CacheItemPriority.Low
	})
;

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 simply do this:

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.

FusionCache Simulator

🧰 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.

đŸ’ŧ Is it Production Ready :tm: ?

Yes!

FusionCache is being used in production on real world projects for years, happily handling millions of requests.

Considering that the FusionCache packages have been downloaded more than 6 million times (thanks everybody!) it may very well be used even more.

And again, if you are using it please ✉ drop me a line, I'd like to know!

Showing the top 20 packages that depend on ZiggyCreatures.FusionCache.

Packages Downloads
ZiggyCreatures.FusionCache.Backplane.StackExchangeRedis
FusionCache backplane for Redis based on the StackExchange.Redis library
4
ZiggyCreatures.FusionCache.Backplane.StackExchangeRedis
FusionCache backplane for Redis based on the StackExchange.Redis library
5
ZiggyCreatures.FusionCache.Backplane.StackExchangeRedis
FusionCache backplane for Redis based on the StackExchange.Redis library
41
ZiggyCreatures.FusionCache.Serialization.NewtonsoftJson
FusionCache serializer based on Newtonsoft Json.NET
4
ZiggyCreatures.FusionCache.Serialization.NewtonsoftJson
FusionCache serializer based on Newtonsoft Json.NET
5
ZiggyCreatures.FusionCache.Serialization.NewtonsoftJson
FusionCache serializer based on Newtonsoft Json.NET
6
ZiggyCreatures.FusionCache.Serialization.NewtonsoftJson
FusionCache serializer based on Newtonsoft Json.NET
44

- Add: support for auto-cloning to avoid undesired mutations - Add: support for triggering fail-safe without involving exceptions - Change: adaptive caching now works even on errors - Change: added multi-targeting, with more granular dependencies to remove the unneeded ones - Perf: more efficient FusionCacheProvider

Version Downloads Last updated
2.3.0 3 06/10/2025
2.2.0 4 05/23/2025
2.2.0-preview-1 4 04/14/2025
2.1.0 35 03/16/2025
2.0.2 3 06/08/2025
2.0.1 4 04/01/2025
2.0.0 4 04/01/2025
2.0.0-preview-4 4 04/01/2025
2.0.0-preview-3 4 04/01/2025
2.0.0-preview-2 3 04/01/2025
2.0.0-preview-1 3 04/01/2025
1.4.1 4 04/01/2025
1.4.0 4 04/01/2025
1.3.0 4 04/01/2025
1.2.0 4 04/01/2025
1.2.0-preview1 4 04/01/2025
1.1.0 4 04/01/2025
1.0.0 5 04/01/2025
1.0.0-preview2 4 04/01/2025
1.0.0-preview1 4 04/01/2025
0.26.0 4 04/01/2025
0.25.0 4 04/01/2025
0.25.0-preview1 4 04/01/2025
0.24.0 6 04/01/2025
0.24.0-preview1 4 04/01/2025
0.23.0 4 04/01/2025
0.22.0 3 04/01/2025
0.21.0 4 04/01/2025
0.21.0-preview2 4 04/01/2025
0.21.0-preview1 4 04/01/2025
0.20.0 5 04/01/2025
0.20.0-preview2 3 04/01/2025
0.20.0-preview1 4 04/01/2025
0.19.0 5 04/01/2025
0.18.0 4 04/01/2025
0.17.0 4 04/01/2025
0.16.0 4 04/01/2025
0.15.0 3 04/01/2025
0.14.0 4 04/01/2025
0.13.0 4 04/01/2025
0.12.0 4 04/01/2025
0.11.1 4 04/01/2025
0.11.0 4 04/01/2025
0.10.0 4 04/01/2025
0.10.0-preview1 6 04/01/2025
0.9.0 3 04/01/2025
0.1.10-beta3 4 04/01/2025
0.1.10-beta2 4 04/01/2025
0.1.10-beta1 4 04/01/2025
0.1.10-alpha2 6 04/01/2025
0.1.10-alpha1 4 04/01/2025
0.1.9 4 04/01/2025
0.1.8 4 04/01/2025
0.1.7 4 04/01/2025
0.1.6 4 04/01/2025
0.1.5 3 04/01/2025
0.1.4 4 04/01/2025
0.1.3 4 04/01/2025
0.1.2 4 04/01/2025
0.1.1 4 04/01/2025
0.1.0 4 04/01/2025