spring4.x hibernate4.x 整合 ehcache 注解 annotate
2016-07-08 17:55
573 查看
摘要: spring4.x hibernate4.x 整合 ehcache 基于 注解 annotate
废话不说 直接贴源码链接 : https://git.oschina.net/alexgaoyh/alexgaoyh.git
使用ehcache来提高系统的性能,现在用的非常多, 也支持分布式的缓存,在hibernate当中作为二级缓存的实现产品,可以提高查询性能。
pom.xml
在项目的src下面添加ehcache的配置文件ehcache.xml
在spring 集成hibernate 的配置文件中,添加如下配置
Spring也使用ehcache, 所以也需要在spring配置文件中添加ehcache的配置
默认情况下二级缓存只会对load get 之类的方法缓存, 想list iterator 之类的方法也使用缓存 必须跟查询缓存一起使用, 重写查询方法
之后进行验证
废话不说 直接贴源码链接 : https://git.oschina.net/alexgaoyh/alexgaoyh.git
使用ehcache来提高系统的性能,现在用的非常多, 也支持分布式的缓存,在hibernate当中作为二级缓存的实现产品,可以提高查询性能。
pom.xml
<dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-ehcache</artifactId> <version>4.1.6.Final</version> </dependency>
在项目的src下面添加ehcache的配置文件ehcache.xml
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd"> <!-- Subdirectories can be specified below the property e.g. java.io.tmpdir/one --> <diskStore path="java.io.tmpdir"/> <!-- Mandatory Default Cache configuration. These settings will be applied to caches created programmtically using CacheManager.add(String cacheName) --> <defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" maxElementsOnDisk="10000000" diskPersistent="false" diskExpiryThreadIntervalSeconds="120" memoryStoreEvictionPolicy="LRU" /> <cache name="org.hibernate.cache.spi.UpdateTimestampsCache" maxElementsInMemory="5000" eternal="true" overflowToDisk="true" /> <cache name="org.hibernate.cache.internal.StandardQueryCache" maxElementsInMemory="10000" eternal="false" timeToLiveSeconds="120" overflowToDisk="true" /> <!-- java文件注解查找cache方法名的策略:如果不指定java文件注解中的region="ehcache.xml中的name的属性值", 则使用name名为com.lysoft.bean.user.User的cache(即类的全路径名称), 如果不存在与类名匹配的cache名称, 则用 defaultCache 如果User包含set集合, 则需要另行指定其cache 例如User包含citySet集合, 则也需要 添加配置到ehcache.xml中 --> <cache name="javaClassName" maxElementsInMemory="2000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" /> </ehcache>
在spring 集成hibernate 的配置文件中,添加如下配置
<!-- 开启查询缓存 --> <prop key="hibernate.cache.use_query_cache">true</prop> <!-- 开启二级缓存 --> <prop key="hibernate.cache.use_second_level_cache">true</prop> <!-- 高速缓存提供程序 --> <!-- 由于spring也使用了Ehcache, 保证双方都使用同一个缓存管理器 --> <prop key="hibernate.cache.region.factory_class"> org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory </prop>
Spring也使用ehcache, 所以也需要在spring配置文件中添加ehcache的配置
<!-- cacheManager, 指定ehcache.xml的位置 --> <bean id="cacheManagerEhcache" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean"> <property name="configLocation"> <value>classpath:ehcache.xml</value> </property> <!-- 由于hibernate也使用了Ehcache, 保证双方都使用同一个缓存管理器 --> <property name="shared" value="true"/> </bean>在类中定义:
@Entity @Table(name = "t_user") @Cache(usage = CacheConcurrencyStrategy.READ_WRITE, region="javaClassName") public class User implements Serializable { }
默认情况下二级缓存只会对load get 之类的方法缓存, 想list iterator 之类的方法也使用缓存 必须跟查询缓存一起使用, 重写查询方法
.setCacheable(true)
criteria.setCacheable(true).list();
之后进行验证
相关文章推荐
- 基于XML的桌面应用
- win2k3SP2,VS2005SP1,SQL2005SP2整合方法分析小结第1/3页
- 基于文本的搜索
- FCKEditor SyntaxHighlighter整合实现代码高亮显示
- struts2 spring整合fieldError问题
- 将CKfinder整合进CKEditor3.0的新方法
- php与paypal整合方法
- 基于文本的留言簿
- 基于文本的访客签到簿
- SpringMVC整合mybatis实例代码
- 详解JDK 5 Annotation 注解之@Target的用法介绍
- Google Map Api和GOOGLE Search Api整合实现代码
- Apache和Tomcat服务器间的区别、联系、整合详细介绍
- java教程之java注解annotation使用方法
- ThinkPHP整合百度Ueditor图文教程
- Angularjs整合微信UI(weui)
- Java中注解的工作原理
- Java注解之Retention、Documented、Inherited介绍
- spring aop两种配置方式
- 深入浅析Java注解框架