使用Spring管理Caffeine缓存(CacheManager+Caffeine)

这篇具有很好参考价值的文章主要介绍了使用Spring管理Caffeine缓存(CacheManager+Caffeine)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1 依赖

使用Spring管理Caffeine缓存的主要pom依赖如下所示。

<dependency>
	<groupId>org.springframework</groupId>
	<artifactId>spring-context</artifactId>
	<version>5.2.8.RELEASE</version>
</dependency>
			
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context-support</artifactId>
    <version>5.2.8.RELEASE</version>
</dependency>

<dependency>
	<groupId>com.github.ben-manes.caffeine</groupId>
	<artifactId>caffeine</artifactId>
	<version>2.9.2</version>
</dependency>

2 配置类

CacheManager配置类如下所示。

@Configuration
@EnableCaching
public class CacheManagerConfig {

    /**
     * 创建基于Caffeine的CacheManager
     */
    @Bean
    @Primary
    public CacheManager caffeineCacheManager() {
        SimpleCacheManager cacheManager = new SimpleCacheManager();
        List<CaffeineCache> caches = Lists.newArrayList();
        for (LocalCacheEnum c : LocalCacheEnum.values()) {
            caches.add(new  CaffeineCache(c.getCacheName(),Caffeine.newBuilder().recordStats()
			.expireAfterWrite(c.getTtl(), TimeUnit.SECONDS).maximumSize(c.getMaxSize()).build()));
        }
        cacheManager.setCaches(caches);
        return cacheManager;
    }
}

@Getter
public enum LocalCacheEnum {

    TestOne(5, 1000, LocalCacheEnum.Test_One),
    TestTwo(10, 2000, LocalCacheEnum.Test_Two),
    ;

    public static final String Test_One = "testOne";
    public static final String Test_Two = "testTwo";


    /** 过期时间 秒 */
    private final long ttl;
    /** 最大数量 */
    private final int maxSize;
    /** 缓存名称 */
    private final String cacheName;

    LocalCacheEnum(long ttl, int maxSize, String cacheName) {
        this.ttl = ttl;
        this.maxSize = maxSize;
        this.cacheName = cacheName;
    }

}

3 使用

使用Caffeine在本地缓存查询结果,使用案例如下所示。

@Cacheable(cacheNames = LocalCacheEnum.Test_One)
public List<String> queryListFromDb() {
	// 具体查询方法
	// ...
}

4 备注

(1)关于maximumSize
当首次设置缓存并尝试存入的数据量大于设置的maximumSize时,Caffeine不会直接报错。但是,当尝试将新数据添加到已满的缓存时,Caffeine会根据其内置的策略来处理这种情况。

具体来说,如果缓存已满并且没有可用的空间来存储新的条目,Caffeine会根据其过期策略和访问策略来决定是否替换旧条目以腾出空间,这可能包括最近最少使用(LRU)策略、时间基的过期策略等。

因此,虽然不会直接报错,但当你尝试向已满的缓存中添加新数据时,Caffeine会默默地处理这种情况,并根据其策略决定是否替换旧数据或忽略新数据。
 文章来源地址https://www.toymoban.com/news/detail-804527.html

到了这里,关于使用Spring管理Caffeine缓存(CacheManager+Caffeine)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 本地缓存无冕之王Caffeine Cache

    本文已收录至GitHub,推荐阅读 👉 Java随想录 微信公众号:Java随想录 原创不易,注重版权。转载请注明原作者和原文链接 目录 淘汰算法 Cache类型 Cache Loading Cache Async Cache Async Loading Cache 驱逐策略 基于大小的过期方式 基于时间的过期方式 基于引用的过期方式 写入外部存储

    2024年02月08日
    浏览(37)
  • 缓存 - Spring Boot 整合 Caffeine 不完全指北

    缓存 - Caffeine 不完全指北 @Cacheable :表示该方法支持缓存。当调用被注解的方法时,如果对应的键已经存在缓存,则不再执行方法体,而从缓存中直接返回。当方法返回null时,将不进行缓存操作。 @CachePut :表示执行该方法后,其值将作为最新结果更新到缓存中,每次都会执

    2024年02月16日
    浏览(49)
  • 微服务---分布式多级缓存集群实现方案(Caffeine+redis+nginx本地缓存+Canal数据同步)

    传统的缓存策略一般是请求到达Tomcat后,先查询Redis,如果未命中则查询数据库,如图: 存在下面的问题: •请求要经过Tomcat处理,Tomcat的性能成为整个系统的瓶颈 •Redis缓存失效时,会对数据库产生冲击 多级缓存就是充分利用请求处理的每个环节,分别添加缓存,减轻T

    2024年02月12日
    浏览(41)
  • SpringBoot使用Caffeine实现内存缓存

    一、引入依赖 caffeine提供了四种缓存策略:分别为手动加载、自动加载、异步手动加载、异步自动加载。 二、手动加载 时间: expireAfterWrite: 基于写入时间 expireAfterAccess:基于访问时间 expireAfter:可以根据读更新写入来调整有效期 权重: maximumWeight:基于权重的容量策略,主要应

    2024年02月07日
    浏览(33)
  • 使用Caffeine实现帖子的缓存来优化网站的运行速度

    结果: 可以看到,第一次记录还未加入缓存,所以是从DB中加载,而后两次访问记录都是从Caffeine中加载的;最后一次访问是强制要求从DB中访问的。

    2024年02月10日
    浏览(44)
  • springboot缓存之CacheManager详解

    spring 提供了spring-cache上层接口给大家实现,其中有一些方便操作缓存的注解,诸如@Cacheable、@CacheEvict等等。今天就来学习一下redis的实现 spring-data-redis. 配置缓存需要配置一个 CacheManager 这个顶层接口有一个抽象类 AbstractCacheManager 各个厂商都会提供一个对应的 CacheManager 实现这

    2024年02月14日
    浏览(24)
  • 多级缓存架构(二)Caffeine进程缓存

    通过本文章,可以完成多级缓存架构中的进程缓存。 在 item-service 中引入 caffeine 依赖 这是Caffeine官方文档地址 1. 配置Config类 创建 config.CaffeineConfig 类 2. 修改controller 在 ItemController 中注入两个 Cache 对象,并修改业务逻辑 Idea结合Docker将springboot放入docker容器中运行,并指定使用

    2024年02月02日
    浏览(54)
  • JVM进程缓存Caffeine

    导入坐标: 写一个配置类: 注入bean // 取数据,包含两个参数: // 参数一:缓存的key // 参数二:Lambda表达式,表达式参数就是缓存的key,方法体是查询数据库的逻辑 // 优先根据key查询JVM缓存,如果未命中,则执行参数二的Lambda表达式 增删改 都要清除缓存

    2024年02月11日
    浏览(53)
  • 缓存 - Caffeine 不完全指北

    https://github.com/ben-manes/caffeine wiki: https://github.com/ben-manes/caffeine/wiki Caffeine是一个用于Java应用程序的高性能缓存框架。它提供了一个强大且易于使用的缓存库,可以在应用程序中使用,以提高数据访问的速度和效率。 下面是一些Caffeine缓存框架的主要特点: 高性能:Caffeine的设

    2024年02月16日
    浏览(44)
  • 地表最帅缓存Caffeine

    缓存是程序员们绕不开的话题,像是常用的本地缓存Guava,分布式缓存Redis等,是提供高性能服务的基础。今天敬姐带大家一起认识一个更高效的本地缓存—— Caffeine 。 Caffeine Cache使用了基于内存的存储策略,并且支持高并发、低延迟,同时还提供了缓存过期、定时刷新、缓存

    2024年02月10日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包