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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值