Java本地缓存

简介: Java本地缓存

Java本地缓存

Java实现本地缓存的方式有很多,其中比较常见的有HashMap、Guava Cache、Caffeine和Encahche等。这些缓存技术各有优缺点,你可以根据自己的需求选择适合自己的缓存技术。以下是一些详细介绍:

  1. HashMap:通过Map的底层方式,直接将需要缓存的对象放在内存中。优点是简单粗暴,不需要引入第三方包,比较适合一些比较简单的场景。缺点是没有缓存淘汰策略,定制化开发成本高。
  2. Guava Cache:Guava是一个Google开源的项目,提供了一些Java工具类和库。Guava Cache是Guava提供的一个本地缓存框架,它使用LRU算法来管理缓存。优点是性能好,支持异步加载和批量操作。缺点是需要引入Guava库。
  3. Caffeine:Caffeine是一个高性能的Java本地缓存库,它使用了基于时间戳的过期策略和可扩展性设计。优点是性能好,支持异步加载和批量操作。缺点是需要引入Caffeine库。
  4. Encahche:Encahche是一个轻量级的Java本地缓存库,它使用了基于时间戳的过期策略和可扩展性设计。优点是性能好,支持异步加载和批量操作。缺点是需要引入Encahche库。

示例代码

1.Guava Cache示例代码

以下是使用Guava Cache实现Java本地缓存的示例代码:

import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache;
import java.util.concurrent.ExecutionException;
public class GuavaCacheExample {
    private static final LoadingCache<String, String> CACHE = CacheBuilder.newBuilder()
            .maximumSize(100) // 设置缓存最大容量为100
            .build(new CacheLoader<String, String>() {
                @Override
                public String load(String key) throws Exception {
                    // 从数据库中查询数据并返回
                    return queryDataFromDatabase(key);
                }
            });
    public static void main(String[] args) throws Exception {
        // 从缓存中获取数据
        String data = CACHE.get("key");
        System.out.println(data);
    }
}

2.Caffeine示例代码

以下是使用Caffeine实现Java本地缓存的示例代码:

import com.github.benmanes.caffeine.cache.Cache;
import com.github.benmanes.caffeine.cache.Caffeine;
import java.util.concurrent.TimeUnit;
public class CaffeineExample {
    private static final Cache<String, String> CACHE = Caffeine.newBuilder()
            .maximumSize(100) // 设置缓存最大容量为100
            .expireAfterWrite(10, TimeUnit.MINUTES) // 设置缓存过期时间为10分钟
            .build();
    public static void main(String[] args) throws Exception {
        // 从缓存中获取数据
        String data = CACHE.get("key", new Callable<String>() {
            @Override
            public String call() throws Exception {
                // 从数据库中查询数据并返回
                return queryDataFromDatabase("key");
            }
        });
        System.out.println(data);
    }
}

3.Encahche示例代码

以下是使用Encahche实现Java本地缓存的示例代码:

import org.ehcache.Cache;
import org.ehcache.CacheManager;
import org.ehcache.config.Builder;
import org.ehcache.config.Configuration;
import org.ehcache.config.units.MemoryUnit;
public class EncahcheExample {
    private static final Cache<String, String> CACHE = CacheManager.create()
            .newCache("myCache", new Configuration()
                    .withSizeOfMaxObjectSize(1024 * 1024) // 设置缓存最大容量为1MB
                    .withExpiry(10, TimeUnit.MINUTES)) // 设置缓存过期时间为10分钟
            .build();
    public static void main(String[] args) throws Exception {
        // 从缓存中获取数据
        String data = CACHE.get("key");
        System.out.println(data);
    }
}
相关文章
|
3月前
|
缓存 JavaScript 前端开发
Java 如何确保 JS 不被缓存
【10月更文挑战第19天】在 Java 中,可以通过设置 HTTP 响应头来确保 JavaScript 文件不被浏览器缓存。方法包括:1. 使用 Servlet 设置响应头,通过 `doGet` 方法设置 `Expires`、`Cache-Control` 和 `Pragma` 头;2. 在 Spring Boot 中配置拦截器,通过 `NoCacheInterceptor` 类和 `WebConfig` 配置类实现相同功能。这两种方法都能确保每次请求都能获取到最新的 JavaScript 内容。
|
5月前
|
缓存 Java Maven
Java本地高性能缓存实践问题之SpringBoot中引入Caffeine作为缓存库的问题如何解决
Java本地高性能缓存实践问题之SpringBoot中引入Caffeine作为缓存库的问题如何解决
128 1
|
5月前
|
缓存 Java Spring
Java本地高性能缓存实践问题之Caffeine中设置刷新机制的问题如何解决
Java本地高性能缓存实践问题之Caffeine中设置刷新机制的问题如何解决
155 1
|
5月前
|
存储 缓存 Java
Java本地高性能缓存实践问题之如何定义Caffeine的缓存
Java本地高性能缓存实践问题之如何定义Caffeine的缓存
|
5月前
|
缓存 Java
Java本地高性能缓存实践问题之Caffeine缓存库中基于时间设置驱逐策略的问题如何解决
Java本地高性能缓存实践问题之Caffeine缓存库中基于时间设置驱逐策略的问题如何解决
|
5月前
|
缓存 Java
Java本地高性能缓存实践问题之AsyncCache中移除一个缓存元素的问题如何解决
Java本地高性能缓存实践问题之AsyncCache中移除一个缓存元素的问题如何解决
|
5月前
|
缓存 Java
Java本地高性能缓存实践问题之使用Caffeine的Cache接口来查找一个缓存元素的问题如何解决
Java本地高性能缓存实践问题之使用Caffeine的Cache接口来查找一个缓存元素的问题如何解决
|
3月前
|
缓存 JavaScript 前端开发
Java 如何确保 JS 不被缓存
大家好,我是 V 哥。本文探讨了 Java 后端确保 JavaScript 不被缓存的问题,分析了文件更新后无法生效、前后端不一致、影响调试与开发及安全问题等场景,并提供了使用版本号、设置 HTTP 响应头、配置静态资源缓存策略和使用 ETag 等解决方案。最后讨论了缓存的合理使用及其平衡方法。
109 0
消息中间件 缓存 监控
169 0
|
5月前
|
缓存 NoSQL Java
【Azure Redis 缓存 Azure Cache For Redis】Redis出现 java.net.SocketTimeoutException: Read timed out 异常
【Azure Redis 缓存 Azure Cache For Redis】Redis出现 java.net.SocketTimeoutException: Read timed out 异常