SSH进阶(7)——Hibernate使用EHCache进行二级缓存

来源:互联网 发布:提高数据运用灵活度 编辑:程序博客网 时间:2024/06/06 13:13

       二级缓存也称为进程级的缓存或SessionFactory级的缓存,二级缓存可以被所有的session共享。二级缓存的生命周期和SessionFactory的生命周期一致,SessionFactory可以管理二级缓存。

       Hibernate的Session在事务级别进行持久化数据的缓存操作。 当然,也有可能分别为每个类(或集合),配置集群、或JVM级别(SessionFactory级别)的缓存。 你甚至可以为之插入一个集群的缓存。注意,缓存永远不知道其他应用程序对持久化仓库(数据库)可能进行的修改 (即使可以将缓存数据设定为定期失效)。

       默认情况下,Hibernate使用EHCache进行JVM级别的缓存(目前,Hibernate已经废弃了对JCS的支持,未来版本中将会去掉它)。 你可以通过设置hibernate.cache.provider_class属性,指定其他的缓存策略, 该缓存策略必须实现org.hibernate.cache.CacheProvider接口。 


二级缓存的配置和使用:


* 将ehcache.xml文件拷贝到src下

* 在hibernate.cfg.xml文件中加入缓存产品提供商

<property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>

* 启用二级缓存,这也是它的默认配置

<property name="hibernate.cache.use_second_level_cache">true</property>

* 指定哪些实体类使用二级缓存

可以在映射文件中采用<cache>标签指定或在hibernate.cfg.xml文件中统一指定。注意使用的策略,通常采用read-only和read-write


          缓存原则:通常读远远大于写的数据进行缓存


         二级缓存主要是缓存实体对象的,了解一级缓存和二级缓存的交互。注意大批量数据更新时,如果配置了二级缓存建议禁用一级缓存和二级缓存的交互。


Hibernate.cfg.xml:

<!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"><hibernate-configuration><session-factory><property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property><property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property><property name="hibernate.connection.username">root</property><property name="hibernate.connection.password">123456</property><property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property><property name="hibernate.show_sql">true</property><!-- 配置缓存提供商 --><property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property><!-- 启用二级缓存,这也是它的默认配置 --><property name="hibernate.cache.use_second_level_cache">true</property><mapping resource="com/bjpowernode/hibernate/Student.hbm.xml"/><mapping resource="com/bjpowernode/hibernate/Classes.hbm.xml"/><!-- 指定Student使用二级缓存 --><class-cache class="com.bjpowernode.hibernate.Student" usage="read-only"/></session-factory></hibernate-configuration>

ehcache.xml:

    <defaultCache        maxElementsInMemory="10000"        eternal="false"        timeToIdleSeconds="120"        timeToLiveSeconds="120"        overflowToDisk="true"        />

Student.hbm.xml:

<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><hibernate-mapping><class name="com.bjpowernode.hibernate.Student" table="t_student"><cache usage="read-only"/><id name="id"><generator class="native"/></id><property name="name"/><many-to-one name="classes" column="classesid"/></class></hibernate-mapping>


建立junit进行单元测试,在两个session中发load查询


public void testCache1() {Session session = null;try {session = HibernateUtils.getSession();session.beginTransaction();Student student = (Student)session.load(Student.class, 1);System.out.println("student.name=" + student.getName());session.getTransaction().commit();}catch(Exception e) {e.printStackTrace();session.getTransaction().rollback();}finally {HibernateUtils.closeSession(session);}try {session = HibernateUtils.getSession();session.beginTransaction();Student student = (Student)session.load(Student.class, 1);//不会发出查询语句,因为配置二级缓存,session可以共享二级缓存中的数据//二级缓存是进程级的缓存System.out.println("student.name=" + student.getName());session.getTransaction().commit();}catch(Exception e) {e.printStackTrace();session.getTransaction().rollback();}finally {HibernateUtils.closeSession(session);}}


       大家看结果可以看出来,二级缓存是进程级别的,session共享二级缓存中的数据,当第二次查询的时候,就是从缓存中读数据,而没有执行hql语句。





总结:          


       缓存的应用很重要,可以性能优化。EhCache可作为进程范围的缓存,存放数据的物理介质可以是内存或硬盘,对Hibernate的查询缓存提供了支持。在学习过程中,还是多多实践才能明白这些原理知识。






0 0
原创粉丝点击