Hibernate一级缓存和二级缓存
Hibernate的缓存介于Hibernate应用和数据库之间,缓存中存放了数据库数据的复制,缓存主要用来减少直接访问数据库的频率,从而提高应用的性能。Hibernate采用二级缓存机制,如果再第一级缓存中没有查询到相应的数据,还可以到第二级缓存内查询,如果在第二级缓存内也没有找到该数据,那么就只好查询数据库。第一级缓存是Session的缓存,第二级缓存是SessionFactory的外置缓存。
1.存放数据的形式
第一级缓存: 互相关联的持久化对象。
第二级缓存:对象的散装数据。
2.缓存的范围
第一级缓存:事物范围,每个事物都拥有单独的第一级缓存。
第二级缓存:进程范围或集群范围,缓存被同一个进程或集群范围内的所有事物共享。
3.并发访问策略
第一级缓存:由于每个事物都拥有单独的第一级缓存,不会出现并发问题,因此无须提供并发访问策略。
第二级缓存:由于多个事物会同时访问第二级缓存中相同数据,因此必须提供适当的并发访问策略,来保证特定的事物隔离级别。
4.数据过期策略。
第一级缓存:没有提供数据过期策略。处于第一级缓存中的对象永远不会过期,除非应用程序显式清空缓存或者清除特定的对象
第二级缓存:必须提供数据过期策略,如基于内存的缓存中对象的最大数目,允许对象处于缓存中的最长时间,以及允许对象处于缓存中的最长空闲时间
5,物理介质。
第一级缓存:内存。
第二级缓存:内存和硬盘。对象的散装数据首先存放在基于内存的缓存中,当内存中对象的数目达到数据过期策略的maxElementsInMemory值,就会把其余的对象写入基于硬盘的缓存中。
6.缓存的软件实现。
第一级缓存:在Hibernate的Session的实现中包含了缓存的实现。
第二级缓存:由第三方提供,Hibernate仅提供了缓存适配器,用于把特定的缓存插件集成到Hibernate中。
7.启用缓存的方式。
第一级缓存:只要应用程序通过Session接口来执行保存、更新、删除、加载或查询数据库数据的操作,hibernate就会启动第一级缓存,把数据库中的数据以对象的形式复制到缓存中。对于批量更新和批量删除操作,如果不希望启动第一级缓存,可以绕过Hibernate API,直接通过JDBC API 来执行批量操作。
第二级缓存:用户可以在单个类或类的单个集合的力度上配置第二级缓存。如果类的实例被经常读但很少被修改,就可以考虑使用第二级缓存。只有为某个类或集合配置了第二级缓存,hibernate在运行时才会把它的实例加入到第二级缓存中。
8.用户管理缓存的方式。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。