- 浏览: 809102 次
- 性别:
- 来自: 西安
文章分类
- 全部博客 (307)
- struts (8)
- hibernate (3)
- spring (32)
- opensourceproject (12)
- javaScript (9)
- primeton EOS (2)
- journey of heart (10)
- Design pattern (6)
- ejb (17)
- point (37)
- Linux&Unix (22)
- ibatis (10)
- AJAX (6)
- DB (26)
- Protocol (6)
- chart (4)
- web server (11)
- webservice (7)
- integration (3)
- tuxedo (5)
- ext (4)
- android (1)
- c/c++ (12)
- JVM (1)
- paginationFrame (2)
- code (2)
- report (1)
- High-performance web (1)
- svn (1)
- JQuery (1)
- workDaily (2)
- cloud (16)
- Python (8)
- English (2)
- shell (5)
- googleCode (1)
- nio (1)
- hyper-v (1)
- debug (3)
- vbs (2)
- openstack (3)
- K8S (1)
- Mesos (0)
- Spark (0)
- Marathon (0)
最新评论
-
钱图大展:
chao2751021 写道lib包哪里去下载,找不到
大型网站用户行为记录的一个实现--基于clickStream(第一部分) -
钱图大展:
无法下载
大型网站用户行为记录的一个实现--基于clickStream(第一部分) -
fm395728572:
shell脚本中用到了环境变量,但是获取不到,例如脚本中有一句 ...
ganymed-ssh2 for Java -
liuhanjiang:
我qq147229234
大型网站用户行为记录的一个实现--基于clickStream(第一部分) -
liuhanjiang:
博主 我利用您提供的方法实现博文中介绍的clickstream ...
大型网站用户行为记录的一个实现--基于clickStream(第一部分)
合理的使用缓存策略,往往在web开发中提高性能起到关键作用。
为Spring集成的Hibernate配置二级缓存 步骤:
1.修改beans.xml,加上 ,我们这里使用的EhCache,还有OSCache,JBossCache 也可以使用
<!-- 打开hibernate的二级缓存 -->
hibernate.cache.use_second_level_cache=true
<!-- 是否使用查询缓存 -->
hibernate.cache.use_query_cache=false
<!-- 使用缓存产品的驱动类 -->
hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> <context:annotation-config/> <!-- 隐式的注入spring的一些bean处理器 比如 AutowiredAnnotationBeanPostProcessor CommonAnnotationBeanPostProcessor ersistenceAnnotationBeanPostProcessor equiredAnnotationBeanPostProcessor --> <!-- 1.配置数据源 --> <context:property-placeholder location="classpath:jdbc.properties"/> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driverClassName}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <!-- 连接池启动时的初始值 --> <property name="initialSize" value="${initialSize}"/> <!-- 连接池的最大值 --> <property name="maxActive" value="${maxActive}"/> <!-- 最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 --> <property name="maxIdle" value="${maxIdle}"/> <!-- 最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 --> <property name="minIdle" value="${minIdle}"/> </bean> <!-- 2.配置 sessionFactory,让spring容器来管理--> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="mappingResources"> <list> <value>cn/com/xinli/bean/Person.hbm.xml</value> </list> </property> <property name="hibernateProperties"> <value> hibernate.dialect=org.hibernate.dialect.MySQL5Dialect <!-- 表示使用根据映射元数据生成表结构 --> hibernate.hbm2ddl.auto=update hibernate.show_sql=true hibernate.format_sql=true <!-- 打开hibernate的二级缓存 --> hibernate.cache.use_second_level_cache=true <!-- 是否使用查询缓存 --> hibernate.cache.use_query_cache=false <!-- 使用缓存产品的驱动类 --> hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider </value> </property> </bean> <!-- 3.配置事务管理器,用来管理 sessionFactory创建的session--> <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory"/> </bean> <!-- 4.配置事务管理器的实现方式 注解 --> <tx:annotation-driven transaction-manager="txManager"/> <bean id="personService" class="cn.com.xinli.service.impl.PersonServiceBean"/> <bean name="/list" class="cn.com.xinli.web.action.PersonAction"/> </beans>
2.*.hbm.xml 中
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="cn.com.xinli.bean"> <class name="Person" table="person"> <!-- 增加缓存支持 --> <cache usage="read-write" region="cn.com.xinli.bean.Person"/> <id name="id" type="int"> <!-- Native主键生成方式会根据不同的底层数据库自动选择 Identity、Sequence、Hilo主键生成方式,这里使用的是mysql 则主键的生成方式为自增长。 --> <generator class="native"/> </id> <property name="name" length="10" not-null="true"/> </class> </hibernate-mapping>
3.配置EHcache的配置文件 ehcache.xml(放在类路径下)
<?xml version="1.0" encoding="UTF-8"?> <!-- defaultCache节点为缺省的缓存策略 maxElementsInMemory 内存中最大允许存在的对象数量 eternal 设置缓存中的对象是否永远不过期 overflowToDisk 把溢出的对象存放到硬盘上 timeToIdleSeconds 指定缓存对象空闲多长时间就过期,过期的对象会被清除掉 timeToLiveSeconds 指定缓存对象总的存活时间 diskPersistent 当jvm结束是是否持久化对象 diskExpiryThreadIntervalSeconds 指定专门用于清除过期对象的监听线程的轮询时间 --> <ehcache> <diskStore path="D:\cache"/> <defaultCache maxElementsInMemory="1000" eternal="false" overflowToDisk="true" timeToIdleSeconds="120" timeToLiveSeconds="180" diskPersistent="false" diskExpiryThreadIntervalSeconds="60"/> <cache name="cn.itcast.bean.Person" maxElementsInMemory="100" eternal="false" overflowToDisk="true" timeToIdleSeconds="300" timeToLiveSeconds="600" diskPersistent="false"/> </ehcache>
测试: 首先使用getBean 从数据库得到一个Person对象,线程终止10秒,在掉getBean ,期间去关闭数据库,如果还能得到Person 对象,则认为第2次得到的Person 对象是从缓存中得到的
测试用例
@Test public void testGetPersonP() { Person person=perService.getPerson(new Integer(1)); System.out.println("id:"+person.getId()); System.out.println("name:"+person.getName()); System.out.println("请关闭数据库..."); try { Thread.sleep(10000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } Person person2=perService.getPerson(new Integer(1)); System.out.println("id:"+person2.getId()); System.out.println("name:"+person2.getName()); }
结果:
Hibernate: select person0_.id as id0_0_, person0_.name as name0_0_ from person person0_ where person0_.id=? id:1 name:胡晓亮 请关闭数据库... id:1 name:胡晓亮
可见缓存生效了。。
- SSH.rar (18 KB)
- 下载次数: 65
发表评论
-
hibernatetemplate类使用
2010-03-19 22:25 1204http://115893520.iteye.com/blog ... -
Spring 中的JdbcTemplate使用
2010-03-19 22:11 35091.JdbcTemplate的execute()方 ... -
SpringAOP 的使用(两种方式)
2009-10-22 13:42 1526使用Spring AOP 拦截 方法,给被拦截的 ... -
第30讲--Spring提供的CharacterEncoding和OpenSessionInView功能
2009-09-19 18:24 1798CharacterEncoding: 在web ... -
第28讲--Struts与Spring集成方案2(Spring集成Struts)
2009-09-17 00:57 1646集成步骤: 1.和方案1一样需要在web. ... -
第27讲--Struts与Spring集成方案1(Struts集成Spring)
2009-09-16 08:25 1834Spring2.5+Hibernate3.3+Stru ... -
第25,26讲 --搭建和配置Spring与Hibernate整合的环境
2009-06-21 11:21 1611Spring2.5+Hibernate3.3+Stru ... -
第24讲 --使用Spring配置文件实现事务管理
2009-06-20 23:56 1773采用基于XML方式配置事务 <bean ... -
第23讲 --使用Spring注解方式管理事务与传播行为详解
2009-06-11 23:19 2251事务传播属性 REQUIR ... -
第21,22讲 --搭建和配置Spring与jdbc整合的环境+Spring集成的jdbc编码和事务
2009-06-10 08:06 2702Spring+JDBC组合开发配置数据源有两种方式: ... -
第20讲--aspectj的切入点语法定义细节
2009-06-06 17:47 3643表达式分析: expression=" ... -
第19讲 --使用Spring配置文件实现AOP
2009-06-06 17:21 1550上面我们是使用注解的方式实现spring AOP的,下面 ... -
第18讲 --使用Spring的注解方式实现AOP的细节
2009-06-06 15:48 1567上一讲我们使用spring注解的方式理由aop技术 ... -
第17讲 --使用Spring的注解方式实现AOP入门
2009-06-05 00:48 2275使用Spring进行面向切面(AOP)编程 要 ... -
第16讲 --使用CGLIB实现AOP功能与AOP概念解释
2009-06-04 07:42 1641当代理对象没有实现 ... -
第15讲 --使用JDK中的Proxy技术实现AOP功能
2009-06-04 07:34 2336当目标类实现了接口,我们可以使用jdk的Proxy ... -
第14讲 --让Spring自动扫描和管理Bean
2009-06-02 23:40 8757通过在classpath自动扫描方式把组件纳入sp ... -
第13讲 --Autowire注解与自动装配
2009-06-02 22:46 31381. Autowire 默认是 ... -
第12讲 --编码剖析@Resource注解的实现原理
2009-06-01 23:14 3296在这一讲开始之前,我们先学习一下jdk5.0 中的一个新 ... -
第11讲 --用@Resource注解完成属性装配
2009-05-31 22:42 7045bean的注入方式有3种: 第一种:使用构造器注 ...
相关推荐
- **二级缓存**: 可选,可提高读取性能。 #### 十五、Session管理 - **Session生命周期管理**: 控制Session的开启和关闭时间。 #### 十六、Hibernate in Spring - **Spring框架与Hibernate的整合**: Spring提供了...
- **二级缓存**: 应用程序级别的缓存。 #### 十七、Session管理 - 管理Session的生命周期,合理利用资源。 #### 十八、Hibernate与Spring集成 - 将Hibernate与Spring框架结合使用,实现更加灵活的开发模式。 - **...
- **缓存管理**:通过一级缓存和二级缓存来优化数据访问速度。 - **Session管理**:如何管理和控制Session的生命周期,确保数据一致性。 - **Hibernate与Spring的集成**:如何在Spring框架中使用Hibernate,以及最佳...
开发者可以通过插件如Ehcache集成二级缓存,并进行配置以优化性能。 八、事件和监听器 Hibernate允许注册监听器来处理特定的事件,如对象的加载、保存、更新和删除。这为实现一些定制行为,如日志记录、版本控制或...
除了以上内容,学习 Hibernate 还需关注事务管理、第二级缓存、实体的生命周期、拦截器等高级特性,以及如何与其他框架如 Spring 集成。 **学习风格建议** - **先脉络,后细节**:首先理解 Hibernate 的整体架构和...
Hibernate内置了第一级缓存(Session级别的缓存)和第二级缓存(SessionFactory级别的缓存)。通过配置,可以提高数据读取速度并减少对数据库的访问。另外,还可以集成第三方缓存系统,如EhCache或Infinispan。 八...
《孙卫琴精通Hibernate源码解析第五部分》深入探讨了Hibernate这一强大ORM框架的源代码,涵盖了第十五章至第十九章的关键内容。这四个章节分别聚焦于Hibernate的核心功能、性能优化、高级特性以及与其他技术的集成。...
- **ORM(Hibernate,Toplink)缓存**:ORM框架通常内置了一级缓存和二级缓存机制,以减少对数据库的访问次数。 - **数据库层的缓存**:在数据库级别进行缓存,如使用MySQL的Query Cache。 - **业务对象的缓存**:...
Hibernate 提供了第一级缓存(Session 缓存)和第二级缓存,提高性能并减少对数据库的访问。还可以集成第三方缓存服务,如 EhCache。 ### 八、事务管理 Hibernate 支持编程式和声明式事务管理。编程式事务管理通过...
一级缓存是默认开启的,而二级缓存需要手动启用。 52. **MyBatis如何集成Spring框架** - 通常通过`SqlSessionFactoryBean`来创建`SqlSessionFactory`实例,然后将其注入到Spring中使用。 53. **MyBatis中如何使用...
本章还包括了Hibernate的工作原理介绍,比如一级缓存和二级缓存的作用机制,以及Session、SessionFactory等核心API的使用方法。 #### 四、关联与组件(Associations and components) 第四章重点关注了Hibernate中...
Hibernate提供了多种性能优化策略,如第二级缓存、批量操作、懒加载和缓存配置等。合理运用这些策略可以显著提高应用程序的运行效率。 九、持久化模型设计 在使用Hibernate时,正确设计实体关系(一对一、一对多、...
2. **第二章:MVC模式和Action类** - MVC设计模式在Web开发中的应用 - Struts 2中的Action类及其生命周期,包括如何编写Action类、处理请求和返回结果 3. **第三章:结果类型与结果配置** - 结果类型(Result ...
21. **第二十一章:缓存技术** - 如何使用Ehcache、Redis等缓存技术提高Web应用性能。 22. **第二十二章:Maven项目管理** - Maven是Java项目的构建工具,讲解其配置和依赖管理。 23. **第二十三章:单元测试与...
10.2.3应用二级缓存 214 10.2.4应用第三方缓存 216 10.3项目实战——借还图书 217 本章小结 224 课后练习 224 第11章spring框架基础 226 11.1spring框架概述 226 11.1.1认识spring框架 226 11.1.2spring框架...