去年暑假,实验室和中国联合航空公司签了一个合同,由我们
帮他们做一套旅游网站。现在项目已经上线数月,前一阵联航那边人员反映服务器内存溢出等性能问题。结合实际,我从前端页面优化、nginx缓存动静分离、后台代码优化、hibernate二级缓存等方面对系统进行局部重构。今天主要记录一下这两天对hibernate缓存的总结。
hibernate缓存有两种:
- 一级缓存
一级缓存默认开启,不需开发者配置干预,因此也无法卸载(就是不得不用)。默认为session
级别,比如你开启一个session
,用这个session
进行一次查询(get或者load),hibernate
会把查询的结果放进缓存中,在该session
关闭之前并且是短时间内如果再做一次这个操作,hibernate会直接从缓存中把数据拿过来而不会再发送sql语句进行查询 - 二级缓存
二级缓存是sessionFactory
级别的缓存。通常情况下,由于sessionFactory
比较重量级,所以它在内存中通常为单例状态。这种情况hibernate
会把session
查询的结果放到二级缓存。这样即便不是同一个session
进行的查询,如果是同样的操作并且是在该sessionFactory
还没有死掉,hibernate
会现在二级缓存中查,查不到再发送sql
语句。
一级缓存属于事务范围,由
hibernate
自己管理,程序员无需干预
二级缓存属于进程范围和集群范围,可以进行配置和动态卸载加载
二级缓存配置:
hibernate 4 + ehcache
首先将
hibernate
下面中的ehcache
三个包导入工程,分别为:ehcache-core-2.4.3.ja、hibernate-ehcache-4.2.21.Final.jar、slf4j-api.jar
将
ehcache.xml
放入到src
目录下-
修改
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>