Table of Contents
Efficient Caching Strategy: Hybrid Caching in Spring Boot Applications
Step 1: Add dependencies
First, add the necessary dependencies to your
The following is the cache configuration:
1. Cache Manager (CacheManager)
Hybrid Caching Workflow
Cache entry added
Cache entry acquisition
Cache Entry Eviction
Summary
Home Java javaTutorial Hybrid Cache Strategy in Spring Boot: A Guide to Redisson and Caffeine Integration

Hybrid Cache Strategy in Spring Boot: A Guide to Redisson and Caffeine Integration

Jan 26, 2025 am 04:04 AM

Efficient Caching Strategy: Hybrid Caching in Spring Boot Applications

In modern application development, performance and scalability are key factors that determine the success or failure of the system. Caching plays a key role in improving these by reducing database load, reducing latency and ensuring a seamless user experience. However, no single caching solution is perfect for all scenarios.

Local caches (such as Caffeine) provide blazing fast speeds because they run in memory and close to the application. They are great for reducing response times for frequently accessed data. Distributed caches (such as Redisson's Redisson), on the other hand, provide scalability and consistency across multiple instances of an application. Distributed caching ensures that all nodes in a distributed system have access to the same latest data, which is critical in a multi-node environment. However, relying solely on local or distributed caching can bring challenges:

    Local cache
  • can become inconsistent in a distributed environment because data updates are not synchronized between nodes.
  • Distributed cache
  • will introduce slight network latency, which may not be suitable for ultra-low latency scenarios.
  • This is where
Hybrid Caching

becomes an effective solution. By combining the advantages of local and distributed caching using Caffeine and Redisson, you get the high performance of local caching speeds while maintaining consistency and scalability with distributed caching sex. This article explores how to implement hybrid caching in Spring Boot applications to ensure optimal performance and data consistency.

Hybrid Cache Strategy in Spring Boot: A Guide to Redisson and Caffeine IntegrationImplementation steps

Step 1: Add dependencies

First, add the necessary dependencies to your

file:

pom.xml

Step 2: Configure cache
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
    <groupId>com.github.ben-manes.caffeine</groupId>
    <artifactId>caffeine</artifactId>
    <version>3.2.0</version>
</dependency>
<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson</artifactId>
    <version>3.43.0</version>
</dependency>
Copy after login
Copy after login

The following is the cache configuration:

Detailed explanation of key components
@Configuration
@EnableCaching
public class CacheConfig implements CachingConfigurer {

    @Value("${cache.server.address}")
    private String cacheAddress;

    @Value("${cache.server.password}")
    private String cachePassword;

    @Value("${cache.server.expirationTime:60}")
    private Long cacheExpirationTime;

    @Bean(destroyMethod = "shutdown")
    RedissonClient redisson() {
        Config config = new Config();
        config.useSingleServer().setAddress(cacheAddress).setPassword(cachePassword.trim());
        config.setLazyInitialization(true);
        return Redisson.create(config);
    }

    @Bean
    @Override
    public CacheManager cacheManager() {
        CaffeineCacheManager cacheManager = new CaffeineCacheManager();
        cacheManager.setCaffeine(Caffeine.newBuilder().expireAfterWrite(cacheExpirationTime, TimeUnit.MINUTES));
        return cacheManager;
    }

    @Bean
    public CacheEntryRemovedListener cacheEntryRemovedListener() {
        return new CacheEntryRemovedListener(cacheManager());
    }

    @Bean
    @Override
    public CacheResolver cacheResolver() {
        return new LocalCacheResolver(cacheManager(), redisson(), cacheEntryRemovedListener());
    }
}
Copy after login
Copy after login

1. Cache Manager (CacheManager)

is responsible for managing the cache lifecycle and providing access to appropriate cache implementations (e.g. local or distributed). In this example, we use

to enable in-memory caching and configure the expiration policy via CacheManager. CaffeineCacheManager Caffeine2. CacheResolver

Dynamically determine which cache to use for a specific operation. Here,

connects local (Caffeine) and distributed (Redisson) caches to ensure that the hybrid strategy is effectively applied. CacheResolver LocalCacheResolver

@Component
public class LocalCacheResolver implements CacheResolver {
    // ... (代码与原文相同) ...
}
Copy after login
Copy after login
3. Cache Entry Removed Listener (CacheEntryRemovedListener)
public class LocalCache implements Cache {
    // ... (代码与原文相同) ...
}
Copy after login
Copy after login

Listens for entries being removed from the distributed cache (Redis) and ensures that they are also removed from the local cache of each node, thus maintaining consistency.

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
    <groupId>com.github.ben-manes.caffeine</groupId>
    <artifactId>caffeine</artifactId>
    <version>3.2.0</version>
</dependency>
<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson</artifactId>
    <version>3.43.0</version>
</dependency>
Copy after login
Copy after login

Hybrid Caching Workflow

Cache entry added

When a method annotated with @Cacheable is executed, the put method will be called. This stores the data in a local cache (Caffeine) and a distributed cache (Redis):

@Configuration
@EnableCaching
public class CacheConfig implements CachingConfigurer {

    @Value("${cache.server.address}")
    private String cacheAddress;

    @Value("${cache.server.password}")
    private String cachePassword;

    @Value("${cache.server.expirationTime:60}")
    private Long cacheExpirationTime;

    @Bean(destroyMethod = "shutdown")
    RedissonClient redisson() {
        Config config = new Config();
        config.useSingleServer().setAddress(cacheAddress).setPassword(cachePassword.trim());
        config.setLazyInitialization(true);
        return Redisson.create(config);
    }

    @Bean
    @Override
    public CacheManager cacheManager() {
        CaffeineCacheManager cacheManager = new CaffeineCacheManager();
        cacheManager.setCaffeine(Caffeine.newBuilder().expireAfterWrite(cacheExpirationTime, TimeUnit.MINUTES));
        return cacheManager;
    }

    @Bean
    public CacheEntryRemovedListener cacheEntryRemovedListener() {
        return new CacheEntryRemovedListener(cacheManager());
    }

    @Bean
    @Override
    public CacheResolver cacheResolver() {
        return new LocalCacheResolver(cacheManager(), redisson(), cacheEntryRemovedListener());
    }
}
Copy after login
Copy after login

Cache entry acquisition

To retrieve data, the system first checks whether the key exists in the local cache. If the key is not found, the distributed cache is queried. If the value exists in the distributed cache, it is added to the local cache for faster subsequent access:

@Component
public class LocalCacheResolver implements CacheResolver {
    // ... (代码与原文相同) ...
}
Copy after login
Copy after login

Cache Entry Eviction

When a cache eviction occurs (for example, via the @CacheEvict annotation), the key will be removed from the distributed cache. Local caches of other nodes will be notified via CacheEntryRemovedListener to remove the same key:

public class LocalCache implements Cache {
    // ... (代码与原文相同) ...
}
Copy after login
Copy after login

Summary

Hybrid cache combines the speed of local memory cache with the scalability and consistency of distributed cache. This approach addresses the limitations of using only local or distributed caches. By integrating Caffeine and Redisson in your Spring Boot application, you can achieve significant performance improvements while ensuring data consistency between application nodes.

Using CacheEntryRemovedListener and CacheResolver ensures that cache entries are kept in sync across all caching tiers, providing an efficient and reliable caching strategy for modern scalable applications. This hybrid approach is especially valuable in distributed systems, where both performance and consistency are critical.

The above is the detailed content of Hybrid Cache Strategy in Spring Boot: A Guide to Redisson and Caffeine Integration. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Is the company's security software causing the application to fail to run? How to troubleshoot and solve it? Is the company's security software causing the application to fail to run? How to troubleshoot and solve it? Apr 19, 2025 pm 04:51 PM

Troubleshooting and solutions to the company's security software that causes some applications to not function properly. Many companies will deploy security software in order to ensure internal network security. ...

How to simplify field mapping issues in system docking using MapStruct? How to simplify field mapping issues in system docking using MapStruct? Apr 19, 2025 pm 06:21 PM

Field mapping processing in system docking often encounters a difficult problem when performing system docking: how to effectively map the interface fields of system A...

How to elegantly obtain entity class variable names to build database query conditions? How to elegantly obtain entity class variable names to build database query conditions? Apr 19, 2025 pm 11:42 PM

When using MyBatis-Plus or other ORM frameworks for database operations, it is often necessary to construct query conditions based on the attribute name of the entity class. If you manually every time...

How do I convert names to numbers to implement sorting and maintain consistency in groups? How do I convert names to numbers to implement sorting and maintain consistency in groups? Apr 19, 2025 pm 11:30 PM

Solutions to convert names to numbers to implement sorting In many application scenarios, users may need to sort in groups, especially in one...

How does IntelliJ IDEA identify the port number of a Spring Boot project without outputting a log? How does IntelliJ IDEA identify the port number of a Spring Boot project without outputting a log? Apr 19, 2025 pm 11:45 PM

Start Spring using IntelliJIDEAUltimate version...

How to safely convert Java objects to arrays? How to safely convert Java objects to arrays? Apr 19, 2025 pm 11:33 PM

Conversion of Java Objects and Arrays: In-depth discussion of the risks and correct methods of cast type conversion Many Java beginners will encounter the conversion of an object into an array...

How to elegantly get entity class variable name building query conditions when using TKMyBatis for database query? How to elegantly get entity class variable name building query conditions when using TKMyBatis for database query? Apr 19, 2025 pm 09:51 PM

When using TKMyBatis for database queries, how to gracefully get entity class variable names to build query conditions is a common problem. This article will pin...

E-commerce platform SKU and SPU database design: How to take into account both user-defined attributes and attributeless products? E-commerce platform SKU and SPU database design: How to take into account both user-defined attributes and attributeless products? Apr 19, 2025 pm 11:27 PM

Detailed explanation of the design of SKU and SPU tables on e-commerce platforms This article will discuss the database design issues of SKU and SPU in e-commerce platforms, especially how to deal with user-defined sales...

See all articles