Home >Java >javaTutorial >How to implement Redis multi-level cache based on Java
After the request reaches tomcat, it first goes to redis to get the cache. If there is no hit, it goes to mysql to get it
# The number of concurrent requests of tomcat
is much smaller than that of redis, so tomcat will become a bottleneck
Use each link of request processing to add cache respectively to reduce the pressure on tomcat and improve service performance
Distributed cache, Such as redis- Advantages: Large storage capacity, good reliability, can be shared in the cluster
- Disadvantages: There is network overhead for accessing the cache
- Scenario: Large amount of cached data, high reliability, needs to be in the cluster Shared data in
Process local cache, such as HashMap, GuavaCache1. Practical case- Advantages: Reading local memory, no network overhead, faster
- Disadvantages: Storage capacity Limited, low reliability (such as lost after restarting), cannot be shared in the cluster
- Scenario: high performance requirements, small amount of cached data
<dependency> <groupId>com.github.ben-manes.caffeine</groupId> <artifactId>caffeine</artifactId> <version>3.0.5</version> </dependency>
package com.erick.cache; import com.github.benmanes.caffeine.cache.Cache; import com.github.benmanes.caffeine.cache.Caffeine; import java.time.Duration; public final class CacheUtil { private static int expireSeconds = 2; public static Cache<String, String> cacheWithExpireSeconds; private static int maxPairs = 1; public static Cache<String, String> cacheWithMaxPairs; static { /*过期策略,写完60s后过期*/ cacheWithExpireSeconds = Caffeine.newBuilder() .expireAfterWrite(Duration.ofSeconds(expireSeconds)) .build(); /*过期策略,达到最大值后删除 * 1. 并不会立即删除,等一会儿才会删除 * 2. 会将之前存储的数据删除掉*/ cacheWithMaxPairs = Caffeine.newBuilder() .maximumSize(maxPairs) .build(); } /*从缓存中获取数据 * 1. 如果缓存中有,则直接从缓存中返回 * 2. 如果缓存中没有,则去数据查询并返回结果*/ public static String getKeyWithExpire(String key) { return cacheWithExpireSeconds.get(key, value -> { return getResultFromDB(); }); } public static String getKeyWithMaxPair(String key) { return cacheWithMaxPairs.get(key, value -> { return getResultFromDB(); }); } private static String getResultFromDB() { System.out.println("数据库查询"); return "db result"; } }
package com.erick.cache; import java.util.concurrent.TimeUnit; public class Test { @org.junit.Test public void test01() throws InterruptedException { CacheUtil.cacheWithExpireSeconds.put("name", "erick"); System.out.println(CacheUtil.getKeyWithExpire("name")); TimeUnit.SECONDS.sleep(3); System.out.println(CacheUtil.getKeyWithExpire("name")); } @org.junit.Test public void test02() throws InterruptedException { CacheUtil.cacheWithMaxPairs.put("name", "erick"); CacheUtil.cacheWithMaxPairs.put("age", "12"); System.out.println(CacheUtil.getKeyWithMaxPair("name")); System.out.println(CacheUtil.getKeyWithMaxPair("age")); TimeUnit.SECONDS.sleep(2); System.out.println(CacheUtil.getKeyWithMaxPair("name")); // 查询不到了 System.out.println(CacheUtil.getKeyWithMaxPair("age")); } }3. Cache consistency1. Common solutions1.1 Set the validity period
The above is the detailed content of How to implement Redis multi-level cache based on Java. For more information, please follow other related articles on the PHP Chinese website!