Hibernate5.x 整合Ehcache

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

  1. 一级缓存
    仅当前事物能够访问,如果事务结束,则缓存也会结束
    evict()将某对象从一级缓存中清除
    clear()将一级缓存中的所有对象清除
    get()/load()都支持一级缓存的读和写
    save()方法会将持久化的对象放入session,如果有大量数据需要保存则应该使用批处理的方式进行保存
    一级缓存被设置为内置且不可卸载,无需任何配置即可使用
  2. 二级缓存
    该缓存可以被应用中的所有事务访问,只有当应用结束,缓存的生命周期才会结束
    二级缓存对应的是sessionFactory级别,所以允许多个session之间共用
    二级缓存默认是关闭的,需要在hibernate.cfg.xml中进行配置
    打开二级缓存
    true
    指定缓存提供者
    org.hibernate.cache.ehcache.internal.SingletonEhcacheRegionFactory
  3. 查询缓存
    查询缓存依赖于二级缓存,可以理解为二级缓存的加强版
    打开查询缓存
    true
    如果要使用查询缓存则需要对其进行启用
    query.setCacheable(true)
    如果用的是注解方式则需要在类上加上一个@Cacheable
    只有当HQL查询语句完全相同时,查询缓存才会生效
    使用查询缓存时必须开启二级缓存否则会引起N+1问题

1. Ehcache的配置

需要使用到的额外的jar包 hibernate-ehcache.jar slf4j-api.jar ehcache-core.jar
在使用jar包时,注意版本是否支持

2. 编写ehcache.xml




    
    
    
    
    
    
    
    
    
    

3. 对应的配置

如果是XML的方式则需要在hibernate.cfg.xml中加入以下配置


如果是注解的方式则需要在类中加入以下注解

@org.hibernate.annotations.Cache(usage =  CacheConcurrencyStrategy.READ_WRITE)

ehcache.xml这个文件会在应用启动时被加载所以需不要额外的配置
好了,Ehcache就已经整合完毕了

你可能感兴趣的:(Hibernate5.x 整合Ehcache)