本地缓存Caffeine在springBoot的简单介绍与使用

2024-04-15 20:04

本文主要是介绍本地缓存Caffeine在springBoot的简单介绍与使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Caffeine 是一个高性能的 Java 缓存库,它提供了灵活的缓存策略,比如自动加载、大小限制、时间过期和引用回收等。这个库是基于 Google Guava 缓存设计而来,但在性能上进行了大幅优化,是当前 Java 应用中常用的缓存解决方案之一。

        其实就是操作本地缓存而已,用起来和redis差不多,但是会快很多,因为是本地的,没有网络开销。

导入依赖:

<dependency><groupId>com.github.ben-manes.caffeine</groupId><artifactId>caffeine</artifactId><version>${caffeine.version}</version>
</dependency>

替换成自己想导入的版本。

基本配置选项:

  • maximumSize(long size)
    设置缓存的最大容量。超过此容量后,旧条目将根据淘汰策略(例如 LRU)被移除。

  • expireAfterWrite(long duration, TimeUnit unit)
    设置缓存条目在指定时间后自写入起失效。这意味着条目在写入缓存后一定时间内有效,之后将被自动移除。

  • expireAfterAccess(long duration, TimeUnit unit)
    设置缓存条目在指定时间内未被访问则失效。如果条目在这段时间内没有被读取或写入,则会被自动移除。

  • weakKeys() / weakValues() / softValues()
    这些方法允许缓存使用弱引用或软引用来存储键或值。这种设置有助于减少内存压力,因为垃圾回收器可以在需要时回收这些条目。

  • refreshAfterWrite(long duration, TimeUnit unit)
    设置在指定时间后刷新缓存条目,这并不会移除条目,而是标记为需要刷新,下次访问时将触发重载。

缓存操作方法

  • get(K key, Function<? super K, V> mappingFunction)
    如果键对应的值不存在,通过提供的函数加载并返回值,同时将其加入缓存。

  • put(K key, V value)
    向缓存中添加或更新键值对。

  • invalidate(Object key)
    从缓存中移除指定的键和对应的值。

  • invalidateAll()
    清空缓存中的所有条目。

  • asMap()
    返回缓存的 ConcurrentMap 视图,这允许你使用标准的 Map 操作来操作缓存。

高级功能

  • recordStats()
    开启缓存的统计功能,比如命中率、平均加载时间等,这对于监控缓存的性能和行为非常有用。

  • build(CacheLoader<K, V> loader)
    使用一个 CacheLoader 来创建一个自动加载的 LoadingCache 实例。如果缓存未命中,将自动调用 CacheLoader 加载数据。

  • buildAsync(CacheLoader<K, CompletableFuture<V>> loader)
    创建一个支持异步操作的缓存,使用 CompletableFuture 作为返回类型,适用于加载数据需要异步操作的场景。

简单使用:

构建Cache
    Cache<String, Integer> stepCache = Caffeine.newBuilder().expireAfterWrite(3, TimeUnit.MINUTES) // 更新后三分钟失效.maximumSize(1000) // 缓存最大1000条.build();

Caffeine.newBuilder() 方法开始构建一个缓存配置。

exipreAfterWrite:是淘汰策略,这里是更新键值对三分钟内没被查询就失效淘汰。

maximumSize:缓存的最大条数。

.build() 方法创建一个 Cache 实例。

get

    public Integer getStepByCode(String businessCode) {return stepCache.get(businessCode, k->segmentMapper.selectById(businessCode).getStep());}

如果cache中查询到了就返回,如果不存在,从数据库中查询,放入cache,然后返回。

这篇关于本地缓存Caffeine在springBoot的简单介绍与使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906788

相关文章

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.