简介
Caffeine是开源的高性能本地缓存库,本地缓存优势在于单机,缺点就是无法共享数据。适合做一级缓存,redis做二级缓存。
SpringBoot整合Caffeine
pom.xml 依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
<groupId>com.github.ben-manes.caffeine</groupId>
<artifactId>caffeine</artifactId>
<version>2.6.2</version>
</dependency>
caffeine配置类
import com.github.benmanes.caffeine.cache.Cache;
import com.github.benmanes.caffeine.cache.Caffeine;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.util.concurrent.TimeUnit;
@Configuration
public class CaffeineConfig {
/**
* 设置缓存驱逐策略
* @return
*/
@Bean
public Cache<Object, Object> user(){
return Caffeine.newBuilder().recordStats()
// 过期设置
.expireAfterWrite(10, TimeUnit.SECONDS)
// 容量大小限制(只能存两个)
.maximumSize(2)
.build();
}
}
测试
@SpringBootTest
public class Test {
@Data
@AllArgsConstructor
public static class User {
private String name;
private Integer age;
}
@Autowired
private Cache<Object, Object> user;
@org.junit.jupiter.api.Test
public void test(){
// 插入数据
user.put("user1", new User("terry", 18));
user.put("user2", new User("java", 28));
// 读取数据
System.out.println(user.asMap());
}
}
打印输出:
{user1=Test.User(name=terry, age=18), user2=Test.User(name=java, age=28)}