Hibernate5.x 整合Ehcache

简介: 首先整理一下hibernate中关于缓存的知识点一级缓存仅当前事物能够访问,如果事务结束,则缓存也会结束evict()将某对象从一级缓存中清除clear()将一级缓存中的所有对象清除get()/load()都支持一级缓存的读和写save...

首先整理一下hibernate中关于缓存的知识点

  1. 一级缓存
    仅当前事物能够访问,如果事务结束,则缓存也会结束
    evict()将某对象从一级缓存中清除
    clear()将一级缓存中的所有对象清除
    get()/load()都支持一级缓存的读和写
    save()方法会将持久化的对象放入session,如果有大量数据需要保存则应该使用批处理的方式进行保存
    一级缓存被设置为内置且不可卸载,无需任何配置即可使用
  2. 二级缓存
    该缓存可以被应用中的所有事务访问,只有当应用结束,缓存的生命周期才会结束
    二级缓存对应的是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>
  3. 查询缓存
    查询缓存依赖于二级缓存,可以理解为二级缓存的加强版
    打开查询缓存
    <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就已经整合完毕了

目录
相关文章
|
7月前
|
SQL 缓存 Java
Hibernate - 整合Ehcache二级缓存使用详解
Hibernate - 整合Ehcache二级缓存使用详解
70 0
|
存储 缓存 Java
Hibernate缓存和ehcache
缓存的概念          计算机领域非常通用的概念。它介于应用程序和永久性数据存储源(如硬盘上的文件或者数据库)之间,其作用是降低应用程序直接读写永久性数据存储源的频率,从而提高应用的运行性能。缓存中的数据是存储源总的数据的拷贝。缓存的物理介质通常是内存。   Hibernate中提供了两个级别的缓存          Session级别的缓存          它是属于事务范围的缓存。这
999 4
|
SQL 缓存 Java
Hibernate-ORM:16.Hibernate中的二级缓存Ehcache的配置
    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------         本篇博客讲述Hibernate中的二级缓存的配置,作者将使用的是ehcache缓存 一,目录   1.
1253 0
|
缓存 Java 数据库连接
|
缓存 Java 数据库连接
|
缓存 Java 数据库连接
|
缓存 Java 数据库连接
Hibernate Ehcache 配置
hibernate 默认使用 ehcache 缓存策略 ehcache 配置 hibernate 配置 true true org.
1004 0
|
Java 数据库连接
如何知道Hibernate已经成功运用了二级缓存EhCache
http://yulimin.javaeye.com/blog/30826 问题是DEBUG之后我也不清楚应该看哪里! DEBUG的信息实在是太多,很难看全! 能否给个实例,指出那里显示了使用了二级缓存!   对Log4J进行分类分级一下,我的如下,你可以进行修改: 代码 log4j.threshold = ALL    log4j.rootLogger =
1258 0
|
7月前
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate