目前格式:HTML/XML
您完全可以在不依赖 Spring 的情况下,通过注解来使用 Java 缓存。下面介绍几种主流方案:
1. JCache(JSR-107)
JSR-107 是 Java 的标准缓存 API,任何兼容的缓存实现(如 Ehcache 3、Hazelcast、Infinispan、或 Caffeine+JCache 桥接)都支持注解驱动:
添加依赖
xml
複製
編輯
<!-- JCache API -->
<dependency>
<groupId>javax.cache</groupId>
<artifactId>cache-api</artifactId>
<version>1.1.1</version>
</dependency>
<!-- 以 Ehcache 为例的 JCache 实现 -->
<dependency>
<groupId>org.ehcache</groupId>
<artifactId>ehcache-jcache</artifactId>
<version>3.10.0</version>
</dependency>
启动 CacheManager(Java SE 示例)
java
複製
編輯
import javax.cache.Caching;
import javax.cache.CacheManager;
import javax.cache.configuration.MutableConfiguration;
CachingProvider provider = Caching.getCachingProvider();
CacheManager cm = provider.getCacheManager();
MutableConfiguration<String, Book> cfg = new MutableConfiguration<>();
cm.createCache("books", cfg);
在方法上使用注解
java
複製
編輯
import javax.cache.annotation.CacheResult;
public class BookService {
@CacheResult(cacheName = "books")
public Book findBookByIsbn(String isbn) {
// … 昂贵的查询操作 …
}
}
启用注解拦截器
在 Jakarta EE 或任意 CDI 容器中,JCache 实现会自动注册对 @CacheResult 等注解的拦截支持。
在 纯 Java SE 环境下,可以启动一个 CDI 容器(如 Weld)来生效这些注解:
java
複製
編輯
import org.jboss.weld.environment.se.Weld;
import org.jboss.weld.environment.se.WeldContainer;
Weld weld = new Weld();
try (WeldContainer c = weld.initialize()) {
BookService svc = c.select(BookService.class).get();
svc.findBookByIsbn("978–0134685991"); // 第一次查询后会被缓存
}
2. MicroProfile Caching
如果您使用支持 MicroProfile 的运行时(WildFly、Payara、Quarkus、Thorntail 等),可以使用 MicroProfile Caching API。它与 JCache 非常类似,注解包名为 org.eclipse.microprofile.caching。
添加依赖
xml
複製
編輯
<dependency>
<groupId>org.eclipse.microprofile.caching</groupId>
<artifactId>microprofile-caching-api</artifactId>
<version>1.0</version>
</dependency>
使用注解
java
複製
編輯
import org.eclipse.microprofile.caching.CacheResult;
public class WeatherClient {
@CacheResult(cacheName = "forecast")
public Forecast getForecast(String city) {
// … 请求天气预报 …
}
}
运行时会自动提供缓存拦截器和后端实现。
3. 其他轻量级库
cache2k
自带注解 @CacheResult(包名 org.cache2k.annotation)。
零配置、体积小、易嵌入。
自定义切面(例如结合 Caffeine + AspectJ)
定义自己的 @Cacheable(或自定义注解),通过 AOP 切面拦截并委托给 Caffeine 缓存。
小结
JSR-107(javax.cache):Java SE(借助 CDI)或 EE 容器通用标准,提供 @CacheResult、@CachePut、@CacheRemoveEntry 等注解。
MicroProfile Caching:在 MicroProfile 容器中使用,与 JCache 用法几乎一致。
cache2k 等轻量库:独立于 Spring、Jakarta EE,零 XML、零复杂依赖。
这些方案都能让您在不引入 Spring 的情况下,用注解优雅地驱动缓存功能。
你說:
介紹cache2k
ChatGPT 說:
已思考 2 秒鐘
以下是 cache2k 的完整介紹,涵蓋核心特性、依賴、程式化使用、注解支持及常見配置:
一、什麼是 cache2k
輕量、高效:完全用 Java 實現,無第三方依賴,jar 體積小(約 200KB)。
極低延遲:同步存取毫秒級別以下,適合延遲敏感應用。
豐富功能:支援時效(TTL)、刷新策略、容量限制、統計與監控。
二、核心特性
零配置即可啟用,也可程式化精細化調整
自動過期(Time To Live)與刷新(Refresh Ahead)
容量限制(Max Entries)與驅逐策略(LRU-based)
同步與異步載入(CacheLoader)
統計與 JMX:可開啟命中率、加載次數等監控
Annotation 模組:支援 @CacheResult 等
無需 CDI:在純 Java SE/EE 環境都能正常運作
三、Maven 依賴
xml
複製
編輯
<!-- 核心 -->
<dependency>
<groupId>org.cache2k</groupId>
<artifactId>cache2k-core</artifactId>
<version>2.8.0.Final</version>
</dependency>
<!-- (選用)注解支持 -->
<dependency>
<groupId>org.cache2k</groupId>
<artifactId>cache2k-annotation</artifactId>
<version>2.8.0.Final</version>
</dependency>
四、程式化使用範例
java
複製
編輯
import org.cache2k.Cache;
import org.cache2k.Cache2kBuilder;
public class Cache2kDemo {
// 建立一個最多 1000 筆、條目存活 5 分鐘的 Cache
Cache<String, String> cache = new Cache2kBuilder<String, String>() {}
.name("myCache")
.entryCapacity(1000)
.expireAfterWrite(5, TimeUnit.MINUTES)
.build();
public String getData(String key) {
// 如果不存在,回傳 null
return cache.peek(key);
}
public void putData(String key, String value) {
cache.put(key, value);
}
public void reloadData(String key) {
// 透過 CacheLoader 自動加載
cache.toCache(key);
}
}
如果要自動加載——
java
複製
編輯
Cache<String, User> userCache = new Cache2kBuilder<String, User>() {}
.name("userCache")
.entryCapacity(5000)
.expireAfterWrite(10, TimeUnit.MINUTES)
.loader(key -> loadUserFromDb(key)) // CacheLoader
.build();
// 使用時,getOrLoad:若 cache 中無,則自動呼叫 loader
User u = userCache.get("alice");
五、注解支持(cache2k-annotation)
開啟注解模組
在 classpath 中加入 cache2k-annotation
使用 @CacheResult
java
複製
編輯
import org.cache2k.annotation.CacheResult;
public class WeatherService {
@CacheResult(cacheName = "forecast")
public Forecast getForecast(String city) {
// 實際呼叫遠端 API…
}
}
啟用 AOP/Interceptor
在 Spring 以外的環境,可使用 AspectJ 或自帶的拦截器(需透過 Cache2kAopConfig 或手動註冊 AOP)。
例如在 CDI/Jakarta EE 中,注解會自動生效;在純 Java SE,可透過 AspectJ weaving。
六、常見配置選項
配置 說明
name(...) Cache 名稱,用於統計與 JMX 匯出
entryCapacity(n) 最大條目數量
expireAfterWrite(t, unit) 寫入後自動過期時間
refreshAhead(t, unit) 到期前自動刷新(非阻塞)
eternal(true) 永久儲存,不過期
strictEviction(true) 嚴格容量限制,超過立即驅逐
loader(...) 指定同步載入資料的函式
asyncEnabled(true) 啟用非同步加載/刷新
monitoring() 啟用命中率、載入時間等統計
七、性能與使用場景
企業級服務:微服務間、API gateway、資料庫查詢結果緩存
實時系統:遊戲伺服器、金融行情、IoT 資料聚合
相較於 Guava Cache 延遲更低、併發更友好;對比 Caffeine 可提供 JCache 及註解整合更簡易;比 Redis 無網路開銷,適合單機場景。
八、延伸資源
官方網站與範例:https://cache2k.org/
GitHub:https://github.com/cache2k/cache2k
Javadoc:https://cache2k.org/apidocs/
您完全可以在不依赖 Spring 的情况下，通过注解来使用 Java 缓存。下面介绍几种主流方案：



1. JCache（JSR-107）

JSR-107 是 Java 的标准缓存 API，任何兼容的缓存实现（如 Ehcache 3、Hazelcast、Infinispan、或 Caffeine+JCache 桥接）都支持注解驱动：



添加依赖



xml

複製

編輯

<!-- JCache API -->

<dependency>

  <groupId>javax.cache</groupId>

  <artifactId>cache-api</artifactId>

  <version>1.1.1</version>

</dependency>

<!-- 以 Ehcache 为例的 JCache 实现 -->

<dependency>

  <groupId>org.ehcache</groupId>

  <artifactId>ehcache-jcache</artifactId>

  <version>3.10.0</version>

</dependency>

启动 CacheManager（Java SE 示例）



java

複製

編輯

import javax.cache.Caching;

import javax.cache.CacheManager;

import javax.cache.configuration.MutableConfiguration;



CachingProvider provider = Caching.getCachingProvider();

CacheManager cm = provider.getCacheManager();

MutableConfiguration<String, Book> cfg = new MutableConfiguration<>();

cm.createCache("books", cfg);

在方法上使用注解



java

複製

編輯

import javax.cache.annotation.CacheResult;



public class BookService {

  @CacheResult(cacheName = "books")

  public Book findBookByIsbn(String isbn) {

    // … 昂贵的查询操作 …

  }

}

启用注解拦截器



在 Jakarta EE 或任意 CDI 容器中，JCache 实现会自动注册对 @CacheResult 等注解的拦截支持。



在 纯 Java SE 环境下，可以启动一个 CDI 容器（如 Weld）来生效这些注解：



java

複製

編輯

import org.jboss.weld.environment.se.Weld;

import org.jboss.weld.environment.se.WeldContainer;



Weld weld = new Weld();

try (WeldContainer c = weld.initialize()) {

  BookService svc = c.select(BookService.class).get();

  svc.findBookByIsbn("978–0134685991");  // 第一次查询后会被缓存

}

2. MicroProfile Caching

如果您使用支持 MicroProfile 的运行时（WildFly、Payara、Quarkus、Thorntail 等），可以使用 MicroProfile Caching API。它与 JCache 非常类似，注解包名为 org.eclipse.microprofile.caching。



添加依赖



xml

複製

編輯

<dependency>

  <groupId>org.eclipse.microprofile.caching</groupId>

  <artifactId>microprofile-caching-api</artifactId>

  <version>1.0</version>

</dependency>

使用注解



java

複製

編輯

import org.eclipse.microprofile.caching.CacheResult;



public class WeatherClient {

  @CacheResult(cacheName = "forecast")

  public Forecast getForecast(String city) {

    // … 请求天气预报 …

  }

}

运行时会自动提供缓存拦截器和后端实现。



3. 其他轻量级库

cache2k



自带注解 @CacheResult（包名 org.cache2k.annotation）。



零配置、体积小、易嵌入。



自定义切面（例如结合 Caffeine + AspectJ）



定义自己的 @Cacheable（或自定义注解），通过 AOP 切面拦截并委托给 Caffeine 缓存。



小结

JSR-107（javax.cache）：Java SE（借助 CDI）或 EE 容器通用标准，提供 @CacheResult、@CachePut、@CacheRemoveEntry 等注解。



MicroProfile Caching：在 MicroProfile 容器中使用，与 JCache 用法几乎一致。



cache2k 等轻量库：独立于 Spring、Jakarta EE，零 XML、零复杂依赖。



这些方案都能让您在不引入 Spring 的情况下，用注解优雅地驱动缓存功能。

















你說：

介紹cache2k





ChatGPT 說：



已思考 2 秒鐘

以下是 cache2k 的完整介紹，涵蓋核心特性、依賴、程式化使用、注解支持及常見配置：



一、什麼是 cache2k

輕量、高效：完全用 Java 實現，無第三方依賴，jar 體積小（約 200KB）。



極低延遲：同步存取毫秒級別以下，適合延遲敏感應用。



豐富功能：支援時效（TTL）、刷新策略、容量限制、統計與監控。



二、核心特性

零配置即可啟用，也可程式化精細化調整



自動過期（Time To Live）與刷新（Refresh Ahead）



容量限制（Max Entries）與驅逐策略（LRU-based）



同步與異步載入（CacheLoader）



統計與 JMX：可開啟命中率、加載次數等監控



Annotation 模組：支援 @CacheResult 等



無需 CDI：在純 Java SE/EE 環境都能正常運作



三、Maven 依賴

xml

複製

編輯

<!-- 核心 -->

<dependency>

  <groupId>org.cache2k</groupId>

  <artifactId>cache2k-core</artifactId>

  <version>2.8.0.Final</version>

</dependency>

<!-- （選用）注解支持 -->

<dependency>

  <groupId>org.cache2k</groupId>

  <artifactId>cache2k-annotation</artifactId>

  <version>2.8.0.Final</version>

</dependency>

四、程式化使用範例

java

複製

編輯

import org.cache2k.Cache;

import org.cache2k.Cache2kBuilder;



public class Cache2kDemo {

  // 建立一個最多 1000 筆、條目存活 5 分鐘的 Cache

  Cache<String, String> cache = new Cache2kBuilder<String, String>() {}

    .name("myCache")

    .entryCapacity(1000)

    .expireAfterWrite(5, TimeUnit.MINUTES)

    .build();



  public String getData(String key) {

    // 如果不存在，回傳 null

    return cache.peek(key);

  }



  public void putData(String key, String value) {

    cache.put(key, value);

  }



  public void reloadData(String key) {

    // 透過 CacheLoader 自動加載

    cache.toCache(key);

  }

}

如果要自動加載——



java

複製

編輯

Cache<String, User> userCache = new Cache2kBuilder<String, User>() {}

  .name("userCache")

  .entryCapacity(5000)

  .expireAfterWrite(10, TimeUnit.MINUTES)

  .loader(key -> loadUserFromDb(key))  // CacheLoader

  .build();



// 使用時，getOrLoad：若 cache 中無，則自動呼叫 loader

User u = userCache.get("alice");

五、注解支持（cache2k-annotation）

開啟注解模組



在 classpath 中加入 cache2k-annotation



使用 @CacheResult



java

複製

編輯

import org.cache2k.annotation.CacheResult;



public class WeatherService {

  @CacheResult(cacheName = "forecast")

  public Forecast getForecast(String city) {

    // 實際呼叫遠端 API…

  }

}

啟用 AOP/Interceptor



在 Spring 以外的環境，可使用 AspectJ 或自帶的拦截器（需透過 Cache2kAopConfig 或手動註冊 AOP）。



例如在 CDI／Jakarta EE 中，注解會自動生效；在純 Java SE，可透過 AspectJ weaving。



六、常見配置選項

配置	說明

name(...)	Cache 名稱，用於統計與 JMX 匯出

entryCapacity(n)	最大條目數量

expireAfterWrite(t, unit)	寫入後自動過期時間

refreshAhead(t, unit)	到期前自動刷新（非阻塞）

eternal(true)	永久儲存，不過期

strictEviction(true)	嚴格容量限制，超過立即驅逐

loader(...)	指定同步載入資料的函式

asyncEnabled(true)	啟用非同步加載/刷新

monitoring()	啟用命中率、載入時間等統計



七、性能與使用場景

企業級服務：微服務間、API gateway、資料庫查詢結果緩存



實時系統：遊戲伺服器、金融行情、IoT 資料聚合



相較於 Guava Cache 延遲更低、併發更友好；對比 Caffeine 可提供 JCache 及註解整合更簡易；比 Redis 無網路開銷，適合單機場景。



八、延伸資源

官方網站與範例：https://cache2k.org/



GitHub：https://github.com/cache2k/cache2k



Javadoc：https://cache2k.org/apidocs/
