首先整理一下hibernate中关于缓存的知识点
- 一级缓存
仅当前事物能够访问,如果事务结束,则缓存也会结束
evict()将某对象从一级缓存中清除
clear()将一级缓存中的所有对象清除
get()/load()都支持一级缓存的读和写
save()方法会将持久化的对象放入session,如果有大量数据需要保存则应该使用批处理的方式进行保存
一级缓存被设置为内置且不可卸载,无需任何配置即可使用- 二级缓存
该缓存可以被应用中的所有事务访问,只有当应用结束,缓存的生命周期才会结束
二级缓存对应的是sessionFactory级别,所以允许多个session之间共用
二级缓存默认是关闭的,需要在hibernate.cfg.xml中进行配置
打开二级缓存<property name="hibernate.cache.use_second_level_cache">true</property>
指定缓存提供者<property name="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.internal.SingletonEhcacheRegionFactory</property>
- 查询缓存
查询缓存依赖于二级缓存,可以理解为二级缓存的加强版
打开查询缓存<property name="hibernate.cache.use_query_cache">true</property>
如果要使用查询缓存则需要对其进行启用query.setCacheable(true)
如果用的是注解方式则需要在类上加上一个@Cacheable
只有当HQL查询语句完全相同时,查询缓存才会生效
使用查询缓存时必须开启二级缓存否则会引起N+1问题
1. Ehcache的配置
需要使用到的额外的jar包 hibernate-ehcache.jar
slf4j-api.jar
ehcache-core.jar
在使用jar包时,注意版本是否支持
2. 编写ehcache.xml
<?xml version="1.0" encoding="UTF-8"?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd"
updateCheck="false">
<!-- 设置硬盘目录 -->
<diskStore path="D:\\temp"/>
<!-- maxElementsInMemory 缓存最大个数 -->
<!-- eternal 是否永久有效,如果该值设置为true,则timeout将失效 -->
<!-- timeToIdleSeconds 失效前的闲置时间 -->
<!-- timeToLiveSeconds 失效前的存活时间 -->
<!-- diskSpoolBufferSizeMB 缓存区的大小 默认30M -->
<!-- maxElementsOnDisk 硬盘最大缓存个数 -->
<!-- overflowToDisk 超出缓存最大个数时写入硬盘 -->
<defaultCache
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
/>
</ehcache>
3. 对应的配置
如果是XML
的方式则需要在hibernate.cfg.xml
中加入以下配置
<class-cache class="pojo.User" usage="read-write"/>
如果是注解的方式则需要在类中加入以下注解
@org.hibernate.annotations.Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
ehcache.xml
这个文件会在应用启动时被加载所以需不要额外的配置
好了,Ehcache就已经整合完毕了