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 启动二级缓存

<property name="cache.use_second_level_cache">true</property>3.2 配置二级缓存的产品xml
<property name="hibernate.cache.region.factory_class"> org.hibernate.cache.ehcache.EhCacheRegionFactory</property>

   3.3 指定二级缓存配置文件的位置  
    ```xml
<property name="hibernate.cache.provider_configuration_file_resource_path">
          ehcache.xml</property>  ```
    3.4  ```Query,Criteria```(查询缓存)由于命中率较低,所以```hibernate```缺省是关闭
          修改cache.use_query_cache为true打开对查询的缓存,
          并且调用query.setCacheable(true)或criteria.setCacheable(true)。
          <propertyname="cache.use_query_cache">true</property>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容