day37 05-HIbernate二级缓存:一级缓存更新同步到二级缓存及二级缓存配置文件

一级缓存的更新会自动同步到二级缓存。

@SuppressWarnings("all")
@Test
// 将内存中的数据写到硬盘
public void demo7(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction();

List<Order> list = session.createQuery("from Order").list();//现在是查询所有的订单 一执行createQuery就会往二级缓存里面放但是它不会用
//所以它就会往硬盘上去写了。但是为什么硬盘上c:/ehcache下的数据文件是空的呢?因为程序执行的速度太快了然后就结束了。然后它没来得及往硬盘去写你的程序就结束了。
//加上断点,你给它点空闲的时间。它就会把多余的对象写到硬盘上了。
tx.commit();
}
    @Test
    // 一级缓存的更新会同步到二级缓存:
    public void demo6(){
        Session session = HibernateUtils.getCurrentSession();
        Transaction tx = session.beginTransaction();
        
        Customer customer = (Customer) session.get(Customer.class, 1);//查询一号客户
        customer.setCname("芙蓉");//customer.setCname是更新一级缓存,它可以同步到二级缓存.你的一级缓存一更新,它把二级缓存也更新了.
        
        tx.commit();
        
        session = HibernateUtils.getCurrentSession();
        tx = session.beginTransaction();
        
        @SuppressWarnings("unused")
        Customer customer2 = (Customer) session.get(Customer.class, 1);//是最新的数据呢?还是原来一级缓存中的数据?
        //一级缓存的更新会同步到二级缓存.为了保证二级缓存的数据没有问题,它肯定会拿到最新的数据.
        tx.commit();
    }
    

<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">

    <diskStore path="c:/ehcache"/><!-- 如果你往硬盘上去写,目标硬盘的路径是java.io.tmpdir java.io.tmpdir是系统临时文件存放的路径 -->
    <!-- 默认的cache可以对所有的持久化类(在hibernate.cfg.xml里面配置的持久化类) -->
    <!-- 假设这里有好几段二级缓存的配置,但是我可能只想用某一个。那就可以通过名字去指定。但是也可以直接使用默认的配置 -->
    <!-- 二级缓存也是内存中的一块区域。它能存放多少个对象呢? -->
    <!-- maxElementsInMemory最大的元素在内存中的数量,默认是一万个-->  <!-- maxElementsInMemory缓存中对象的最大数目 -->
    <!-- eternal 设置对象是否是永久的 -->
    <!--如果用cache标签就是给它设置一名字 -->
    <!-- timeToIdleSeconds 空闲时间 -->
    <!-- timeToLiveSeconds 存活的时间 -->
    <!-- overflowToDisk 假设maxElementsInMemory="10000",数据库有两万条记录呢 超出内存的区域中是否到硬盘上  是否把你的内存中超出的部分写到硬盘上 超出内存的部分写到硬盘上 如果值为true,可以往硬盘上写了-->
    
    <defaultCache  
            maxElementsInMemory="5"   
            eternal="false"  
            timeToIdleSeconds="120"   
            timeToLiveSeconds="120"   
            overflowToDisk="true"  
            maxElementsOnDisk="10000000"
            diskPersistent="false"
            diskExpiryThreadIntervalSeconds="120"
            memoryStoreEvictionPolicy="LRU"
            />
</ehcache>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">

    <diskStore path="c:/ehcache"/><!-- 如果你往硬盘上去写,目标硬盘的路径是java.io.tmpdir java.io.tmpdir是系统临时文件存放的路径 -->
    <!-- 默认的cache可以对所有的持久化类(在hibernate.cfg.xml里面配置的持久化类) -->
    <!-- 假设这里有好几段二级缓存的配置,但是我可能只想用某一个。那就可以通过名字去指定。但是也可以直接使用默认的配置 -->
    <!-- 二级缓存也是内存中的一块区域。它能存放多少个对象呢? -->
    <!-- maxElementsInMemory最大的元素在内存中的数量,默认是一万个-->  <!-- maxElementsInMemory缓存中对象的最大数目 -->
    <!-- eternal 设置对象是否是永久的 -->
    <!--如果用cache标签就是给它设置一名字 -->
    <!-- timeToIdleSeconds 空闲时间 -->
    <!-- timeToLiveSeconds 存活的时间 -->
    <!-- overflowToDisk 假设maxElementsInMemory="10000",数据库有两万条记录呢 超出内存的区域中是否到硬盘上  是否把你的内存中超出的部分写到硬盘上 超出内存的部分写到硬盘上 如果值为true,可以往硬盘上写了-->
    
    <defaultCache  
            maxElementsInMemory="5"   
            eternal="false"  
            timeToIdleSeconds="120"   
            timeToLiveSeconds="120"   
            overflowToDisk="true"  
            maxElementsOnDisk="10000000"
            diskPersistent="false"
            diskExpiryThreadIntervalSeconds="120"
            memoryStoreEvictionPolicy="LRU"
            />
</ehcache>
原文地址:https://www.cnblogs.com/ZHONGZHENHUA/p/6709215.html