KB#0002: When to Use a Distributed Cache Server

ABP provides a distributed cache service that is based on ASP.NET Core's distributed cache. This document explains when you need to have a separate cache server for your applications.

Understanding the Default Cache Service

Default implementation of the cache service works in-memory. Memory cache is only useful if you are building a monolith application and you run a single instance of your application. For other cases, you should use a real distributed cache server.

Here are a few example cases where you should use a distributed cache server:

  • You have a monolith application, but you run multiple instances of that application concurrently, for example, in a clustered environment
  • You build a microservice or any kind of distributed system
  • You have web multiple applications in your solution and they should share the same cache

The problem is obvious: If each application instance uses its internal in-memory cache, and if two or more applications cache the same data, it is probable that they will cache different copies of the data. In that case, there is no way to invalidate/refresh that data in every application's memory when the data changes.

What is a Distributed Cache Server

A distributed cache server (e.g. Redis) stores cache objects in a separate server application and allows multiple applications/processes to share the same cache objects. In that way;

  • All applications/services and all their instances use the same cache store and share the same cached objects. Once an application instance refreshes a cached object, all others use the new object.
  • Even if your applications stop and restart, the cached objects are not lost, since they are managed by a separate cache server.

How to Use a Distributed Cache Server

ABP solution templates come with Redis configured when it is certainly necessary. For example;

  • The microservice startup template always comes with Redis configured and also included as a docker container.

  • The application startup template comes with Redis configured when you select multiple applications, tiered architecture, or some other configuration that requires a distributed cache server.

In other cases, to keep the dependencies minimal, they come with the default (in-memory) cache configuration. In those cases, if you need a distributed cache server, you should manually switch to a distributed cache provider for your application.

See the Redis Cache document if you need to use Redis as the distributed cache server. See ASP.NET Core's documentation to see how to switch to another cache provider.

Installing a Redis Server to Your Local Environment

If you want to use Redis as your distributed cache provider in your development environment, you can simply use the official Redis docker image. Once you have Docker in your local machine, you can use the following command to run a Redis container and map the default Redis port:

docker run -p 6379:6379 --name RedisServer -d redis

You can check the official Redis docker image document for more options.

See Also

Contributors


Last updated: January 08, 2025 Edit this page on GitHub

Was this page helpful?

Please make a selection.

To help us improve, please share your reason for the negative feedback in the field below.

Please enter a note.

Thank you for your valuable feedback!

Please note that although we cannot respond to feedback, our team will use your comments to improve the experience.

In this document
Community Talks

Layered vs Modular vs Microservices... Which one is best for you?

09 Jan, 17:00
Online
Watch the Event
Mastering ABP Framework Book
Mastering ABP Framework

This book will help you gain a complete understanding of the framework and modern web application development techniques.

Learn More