本文源码:GitHub·点这里 || GitEE·点这里
EhCache是一个纯Java的进程内缓存框架,具有快速、上手简单等特点,是Hibernate中默认的缓存提供方。
Hibernate三级缓存机制简介:
一级缓存:基于Session级别分配一块缓存空间,缓存访问的对象信息。Session关闭后会自动清除缓存。
二级缓存:是SessionFactory对象缓存,可以被创建出的多个 Session 对象共享,二级缓存默认是关闭的,如果要使用需要手动开启,并且依赖EhCache组件。
三级缓存:查询缓存,配置开启该缓存的情况下,重复使用一个sql查询某个范围内的数据,会进行缓存。
Ehcache:直接在Jvm虚拟机中缓存,速度快,效率高,不适合处理大规模缓存数据,在分布式环境下,缓存数据共享操作复杂;
Redis:作为独立的缓存中间件,在分布式缓存系统中非常好用,缓存数据共享,有效支撑大量数据缓存,支持哨兵模式,或者集群模式的高可用成熟方案;
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-cacheartifactId>
dependency>
<dependency>
<groupId>net.sf.ehcachegroupId>
<artifactId>ehcacheartifactId>
dependency>
基础配置
spring:
cache:
ehcache:
config: classpath:ehcache.xml
启动类注解
@EnableCaching
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class,args) ;
}
}
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">
<diskStore path="java.io.tmpdir"/>
<defaultCache
maxElementsInMemory="1000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
maxElementsOnDisk="10000000"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
<persistence strategy="localTempSwap"/>
defaultCache>
<cache name="userEntity"
maxElementsInMemory="1000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
maxElementsOnDisk="10000000"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
<persistence strategy="localTempSwap"/>
cache>
ehcache>
配置参数说明
maxElementsOnDisk:磁盘缓存中最多可以存放的元素数量;
eternal:缓存中对象是否永久有效;
timeToIdleSeconds:当eternal=false时使用,缓存数据有效期(单位:秒),时间段内没有访问该元素,将被清除;
timeToLiveSeconds:缓存数据的存活时间;
maxElementsInMemory:内存中最多可以存放的元素数量,overflowToDisk=true,则会将Cache中多出的元素放入磁盘文件中,若overflowToDisk=false,则根据memoryStoreEvictionPolicy策略替换Cache中原有的元素;
diskExpiryThreadIntervalSeconds:磁盘缓存的清理线程运行间隔;
memoryStoreEvictionPolicy:缓存释放策略,LRU会优先清理最少使用的缓存;
localTempSwap:持久化策略,当堆内存或者非堆内存里面的元素已经满了的时候,将其中的元素临时的存放在磁盘上,重启后就会消失;
@Service
public class CacheService {
private static final Logger LOGGER = LoggerFactory.getLogger(CacheService.class);
@Resource
private UserMapper userMapper ;
@Cacheable(value="userEntity") // 在缓存有效期内,首次查询才访问数据库
public UserEntity getById (Integer id){
// 通过日志,标识方法是否执行
LOGGER.info("getById..."+id);
return userMapper.selectById(id) ;
}
@CacheEvict(value="userEntity",key = "#id") //该ID数据更新,清空该ID缓存
public void updateUser(Integer id) {
UserEntity user = new UserEntity() ;
user.setId(id);
user.setUserName("myCache");
userMapper.updateById(user);
}
}
@Cacheable:注解标记在一个方法上,也可以标记在一个类上,标记在一个方法上表示该方法支持缓存,该方法被调用后将其返回值缓存起来,下次同样的请求参数执行该方法时可以直接从缓存中获取结果,而不需要再次执行该方法。
@CacheEvict:注解标记在需要清除缓存元素的方法或类上的,当标记在一个类上时表示其中所有的方法的执行都会触发缓存的清除操作,并且可以按照指定属性清除。
GitHub·地址
https://github.com/cicadasmile/middle-ware-parent
GitEE·地址
https://gitee.com/cicadasmile/middle-ware-parent
推荐阅读:SpringBoot进阶系列
序号 | 文章标题 |
---|---|
01 | Boot2 整合 shard-jdbc 中间件,实现数据分库分表 |
02 | Boot2 整合 JavaMail ,实现异步发送邮件功能 |
03 | Boot2 整合 RocketMQ ,实现请求异步处理 |
04 | Boot2 整合 Swagger2 ,构建接口管理界面 |
05 | Boot2 整合 QuartJob ,实现定时器实时管理 |
06 | Boot2 整合 Redis集群 ,实现消息队列场景 |
07 | Boot2 整合 Dubbo框架 ,实现RPC服务远程调用 |
08 | Boot2 整合 ElasticSearch框架,实现高性能搜索引擎 |
09 | Boot2 整合 JWT 框架,解决Token跨域验证问题 |
10 | Boot2 整合 FastDFS 中间件,实现文件分布管理 |
11 | Boot2 整合 Shiro 框架,实现用户权限管理 |
12 | Boot2 整合 Security 框架,实现用户权限管理 |
13 | Boot2 整合 ClickHouse数据库,实现数据高性能查询分析 |
14 | Boot2 整合 Drools规则引擎,实现高效的业务规则 |
15 | Boot2 整合 多数据源,配置MybatisPlus增强插件 |
16 | Boot2 整合 Zookeeper组件,管理架构中服务协调 |
17 | Boot2 整合Nacos组件,环境搭建和入门案例详解 |
18 | 文件系统(01):基于Boot2框架,管理Excel和PDF |
18 | 文件系统(02):基于Boot2框架,管理Xml和CSV |
19 | Boot2 整合 Kafka组件,应用案例和流程详解 |
20 | Boot2 整合 ElasticJob框架,定制化管理流程 |
21 | Boot2 整合JTA组件,多数据源事务管理 |
22 | Boot2 整合FreeMarker模板,完成页面静态化处理 |
23 | Boot2 整合MinIO中间件,实现文件便捷管理 |