hibernate内建的开源产品提供的高速缓存
-
EHCache
(org.hibernate.cache.EhCacheProvider)
-
OSCache
(org.hibernate.cache.OSCacheProvider)
-
SwarmCache
(org.hibernate.cache.SwarmCacheProvider)
-
JBoss TreeCache
(org.hibernate.cache.TreeCacheProvider)
Each cache provides different capacities in terms of performance, memory use, and configuration possibilities:
- EHCache
is a fast, lightweight, and easy-to-use in-process cache. It supports
read-only and read/write caching, and memory- and disk-based caching.
However, it does not support clustering.
- OSCache
is another open-source caching solution. It is part of a larger
package, which also provides caching functionalities for JSP pages or
arbitrary objects. It is a powerful and flexible package, which, like
EHCache, supports read-only and read/write caching, and memory- and
disk-based caching. It also provides basic support for clustering via
either JavaGroups or JMS.
- SwarmCache
is a simple cluster-based caching solution based on JavaGroups. It
supports read-only or nonstrict read/write caching (the next section
explains this term). This type of cache is appropriate for applications
that typically have many more read operations than write operations.
- JBoss TreeCache
is a powerful replicated (synchronous or asynchronous) and
transactional cache. Use this solution if you really need a true
transaction-capable caching architecture.
ehcache
<hibernate-configuration>
<session-factory>
...
<property name="hibernate.cache.provider_class">
org.hibernate.cache.EHCacheProvider
</property>
...
</session-factory>
</hibernate-configuration>
<class name="cascade.Category" table="CATEGORY">
<cache usage="read-write"/>
<ehcache>
<diskStore path="java.io.tmpdir"/>
<defaultCache
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
diskPersistent="false"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"
/>
<cache name="cascade.Category"
maxElementsInMemory="300"
eternal="true"
overflowToDisk="false"
/>
</ehcache>
eternal='true'通过超时禁用清除
overflowToDisk="false"禁用基于磁盘的高速缓存溢出
timeToIdleSeconds="120"定义了以秒为单位的从一个元素最后一次在高速缓存中被访问开始的过期时间
timeToLiveSeconds="120"定义了以秒为单位的从元素被添加到高速缓存中开始的最大过期时间
查询缓存
<property name="hibernate.cache.use_query_cache">true</property>
分享到:
相关推荐
Hibernate二级缓存是一种提高应用程序性能的技术,它将数据存储在SessionFactory级别的缓存中,使得数据可以在不同的Session之间共享。这与一级缓存(Session级别)不同,一级缓存仅存在于单个Session生命周期内,当...
Hibernate 二级缓存是针对SessionFactory级别的全局缓存,与一级缓存(Session级别)不同,一级缓存只在单个Session生命周期内有效。二级缓存则允许不同Session之间共享数据,提高了数据访问效率,减少了对数据库的...
Hibernate 二级缓存
在这个"hibernate二级缓存实例"中,我们将深入探讨二级缓存的原理、配置以及在实际项目中的应用。 首先,我们需要了解一级缓存和二级缓存的区别。一级缓存是Session级别的,每个Session都有自己的一级缓存,用于...
**hibernate二级缓存详解** Hibernate作为Java领域中广泛使用的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,在处理大量数据时,性能优化显得尤为重要,这就是二级缓存的作用。本文将深入探讨Hibernate...
**Hibernate 二级缓存总结整理** 在Java的持久化框架中,Hibernate是一个广泛使用的ORM(对象关系映射)工具,它极大地简化了数据库操作。在处理大数据量或高并发的场景下,为了提高性能和减少数据库负载,...
Hibernate二级缓存是Java开发中使用Hibernate框架进行数据持久化时优化性能的一种重要技术。它在一级缓存(Session级别的缓存)的基础上,提供了一个全局的、跨会话的数据存储层,可以显著减少对数据库的访问,从而...
二级缓存是 Hibernate 缓存策略的一部分,它在应用程序的多个会话之间共享数据,进一步优化了数据库访问效率。 二级缓存分为以下关键知识点: 1. **一级缓存与二级缓存的区别**: - 一级缓存:每个 Hibernate ...
本篇文章将深入探讨Hibernate二级缓存的概念、工作原理以及如何在实际项目中设置和使用。 **一、二级缓存概念** 一级缓存是每个Hibernate Session内部的一个内存区域,用于存储Session期间的操作对象。当Session...
本篇将详细介绍Hibernate二级缓存的概念、作用以及所需jar包的作用。 一、Hibernate二级缓存概念 Hibernate的一级缓存是指Session级别的缓存,每个Session内部都有一个一级缓存,用于存储实体对象,当Session关闭时...
本篇文章将深入探讨Hibernate的二级缓存机制,以及如何进行一级缓存与二级缓存的同步,同时还会介绍二级缓存的配置文件设置。 一级缓存是Hibernate默认提供的缓存,每个SessionFactory实例都有一个一级缓存。当对象...