hibernate 缓存(一级缓存和二级缓存)

去年暑假,实验室和中国联合航空公司签了一个合同,由我们
帮他们做一套旅游网站。现在项目已经上线数月,前一阵联航那边人员反映服务器内存溢出等性能问题。结合实际,我从前端页面优化、nginx缓存动静分离、后台代码优化、hibernate二级缓存等方面对系统进行局部重构。今天主要记录一下这两天对hibernate缓存的总结。

hibernate缓存有两种:

  1. 一级缓存
    一级缓存默认开启,不需开发者配置干预,因此也无法卸载(就是不得不用)。默认为session级别,比如你开启一个session,用这个session进行一次查询(get或者load),hibernate会把查询的结果放进缓存中,在该session关闭之前并且是短时间内如果再做一次这个操作,hibernate会直接从缓存中把数据拿过来而不会再发送sql语句进行查询
  2. 二级缓存
    二级缓存是sessionFactory级别的缓存。通常情况下,由于sessionFactory比较重量级,所以它在内存中通常为单例状态。这种情况hibernate会把session查询的结果放到二级缓存。这样即便不是同一个session进行的查询,如果是同样的操作并且是在该sessionFactory还没有死掉,hibernate会现在二级缓存中查,查不到再发送sql语句。

一级缓存属于事务范围,由hibernate自己管理,程序员无需干预
二级缓存属于进程范围和集群范围,可以进行配置和动态卸载加载

二级缓存配置:

  hibernate 4 + ehcache      
  1. 首先将hibernate下面中的ehcache三个包导入工程,分别为:ehcache-core-2.4.3.ja、hibernate-ehcache-4.2.21.Final.jar、slf4j-api.jar

  2. ehcache.xml 放入到src目录下

  3. 修改hibernate.cfg.xml文件
    3.1 启动二级缓存

true3.2 配置二级缓存的产品xml
org.hibernate.cache.ehcache.EhCacheRegionFactory

   3.3 指定二级缓存配置文件的位置  
    ```xml

          ehcache.xml  ```
    3.4  ```Query,Criteria```(查询缓存)由于命中率较低,所以```hibernate```缺省是关闭
          修改cache.use_query_cache为true打开对查询的缓存,
          并且调用query.setCacheable(true)或criteria.setCacheable(true)。
          true

你可能感兴趣的:(hibernate 缓存(一级缓存和二级缓存))