4 开始使用OSCache中的缓存组件 OSCache中按照缓存范围的不同分为两种不同的方式:一种是缓存JSP页面中部分或者全部内容,一种是基于整个页面文件的缓存。4.1 JSP部分内容缓存4.1.1 Cache-OSCache提供的缓存标签 这是OSCache提供的标签库中最重要的一个标签,包括在标签中的内容将应用缓存机制进行处理,处理的方式将取决于编程者对cache标签属性的设置。第一次请求到达时,标签中的内容被处理并且缓存起来,当下一个请求到达时,缓存系统会检查这部分内容的缓存是否已经失效,主要是以下几项:1. 缓存时间超过了cache标签设置的time或者duration属性规定的超时时间2. cron属性规定的时间比缓存信息的开始时间更晚3. 标签中缓存的内容在缓存后又被重新刷新过4. 其他缓存超期设定 如果符合上面四项中的任何一项,被缓存的内容视为已经失效,这时被缓存的内容将被重新处理并且返回处理过后的信息,如果被缓存的内容没有失效,那么返回给用户的将是缓存中的信息。cache标签的属性说明:key - 标识缓存内容的关键词。在指定的作用范围内必须是唯一的。默认的key是被访问页面的URI和后面的请求字符串。你可以在同一个页面中使用很多cache标签而不指定他的key属性,这种情况下系统使用该页面的URI和后面的请求字符串,另外再自动给这些key增加一个索引值来区分这些缓存内容。但是不推荐采用这样的方式。scope - 缓存发生作用的范围,可以是application或者session time - 缓存内容的时间段,单位是秒,默认是3600秒,也就是一个小时,如果设定一个负值,那么这部分被缓存的内容将永远不过期。 duration - 指定缓存内容失效的时间,是相对time的另一个选择,可以使用简单日期格式或者符合USO-8601的日期格式。如:duration='PT5M' duration='5s'等refresh - false 或者true。如果refresh属性设置为true,不管其他的属性是否符合条件,这部分被缓存的内容都将被更新,这给编程者一种选择,决定什么时候必须刷新。 mode - 如果编程者不希望被缓存的内容增加到给用户的响应中,可以设置mode属性为"silent" 其它可用的属性还包括:cron 、groups、language、refreshpolicyclass、refreshpolicyparam。上面的这些属性可以单独使用,也可以根据需要组合使用,下面的例子将讲解这些常用属性的使用方式。4.1.2 Cache标签实例分析:1. 最简单的cache标签用法使用默认的关键字来标识cache内容,超时时间是默认的3600秒<cache:cache><%//自己的JSP代码内容%></cache:cache> 2. 用自己指定的字符串标识缓存内容,并且设定作用范围为session。<cache:cache key="foobar" scope="session"><%//自己的JSP代码内容%></cache:cache> 3. 动态设定key值,使用自己指定的time属性设定缓存内容的超时时间,使用动态refresh值决定是否强制内容刷新。因为OSCache使用key值来标识缓存内容,使用相同的key值将会被认为使用相同的的缓存内容,所以使用动态的key值可以自由的根据不同的角色、不同的要求决定使用不同的缓存内容。<cache:cache key="<%= product.getId() %>" time="1800" refresh="<%= needRefresh %>"><%//自己的JSP代码内容%></cache:cache> 4. 设置time属性为负数使缓存内容永不过期<cache:cache time="-1"><%//自己的JSP代码内容%>5. 使用duration属性设置超期时间<cache:cache duration='PT5M'><%//自己的JSP代码内容%>6. 使用mode属性使被缓存的内容不加入给客户的响应中<cache:cache mode='silent'><%//自己的JSP代码内容%>4.2 用CashFilter实现页面级缓存 在OSCache组件中提供了一个CacheFilter用于实现页面级的缓存,主要用于对web应用中的某些动态页面进行缓存,尤其是那些需要生成pdf格式文件/报表、图片文件等的页面,不仅减少了数据库的交互、减少数据库服务器的压力,而且对于减少web服务器的性能消耗有很显著的效果。这种功能的实现是通过在web.xml中进行配置来决定缓存哪一个或者一组页面,而且还可以设置缓存的相关属性,这种基于配置文件的实现方式对于J2EE来说应该是一种标准的实现方式了。[注] 只有客户访问时返回http头信息中代码为200(也就是访问已经成功)的页面信息才能够被缓存1. 缓存单个文件修改web.xml,增加如下内容,确定对/testContent.jsp页面进行缓存。<filter><filter-name>CacheFilter</filter-name><filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class></filter><filter-mapping><filter-name>CacheFilter</filter-name><!-对/testContent.jsp页面内容进行缓存--><url-pattern>/testContent.jsp</url-pattern></filter-mapping>2. 缓存URL pattern修改web.xml,增加如下内容,确定对*.jsp页面进行缓存。<filter><filter-name>CacheFilter</filter-name><filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class></filter><filter-mapping><filter-name>CacheFilter</filter-name><!-对所有jsp页面内容进行缓存--><url-pattern>*.jsp</url-pattern></filter-mapping>3. 自己设定缓存属性在页面级缓存的情况下,可以通过设置CacheFilter的初始属性来决定缓存的一些特性:time属性设置缓存的时间段,默认为3600秒,可以根据自己的需要只有的设置而scope属性设置,默认为application,可选项包括application、session<filter><filter-name>CacheFilter</filter-name><filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class><init-param><param-name>time</param-name><param-value>600</param-value></init-param><init-param><param-name>scope</param-name><param-value>session</param-value></init-param></filter><filter-mapping><filter-name>CacheFilter</filter-name><!-对所有jsp页面内容进行缓存--><url-pattern>*.jsp</url-pattern></filter-mapping>
5 性能测试结果5.1 测试环境系统平台:windows 2000 高级服务器/ P3 800 /512M内存web服务器:websphere 5.0数据库服务器:mysql 4.0.18-nt性能测试用工具:apache Jmeter5.2 测试计划 这次性能测试对比方为使用缓存和不使用缓存两种,他们的访问代码都是一样的:通过数据源从本地mysql数据库中获取person表的所有记录,然后显示在页面上。测试中将模仿10个用户,每个用户发起5次请求,然后统计所有访问花费的时间。5.3 测试结果 使用缓存后的测试结果 不使用缓存时的测试结果 所有请求花费的总时间(毫秒) 20569 22870 性能测试的详细结果请大家查看下载内容中的《不使用cache时的系统性能测试结果.txt》和《使用cache后系统性能测试结果.txt》6 总结 在J2EE系统中,我们经常需要处理一些特殊的动态内容,这些内容在一个时间段内的变更非常有限,但是又不得不将他们确定为动态内容进行输出,而且非常消耗数据库系统资源或者web服务器的资源,这时我们就可以采用Cache----一种用于提高系统响应速度、改善系统运行性能的技术----来优化我们的系统。尤其是在Web应用中,这种处理可以很显著的改善系统运行性能。 本文中作者给大家介绍一个实现J2EE框架中Web应用层缓存功能的开放源代码项目----OSCache。它提供了在J2EE系统中实现缓存需要的丰富的功能。通过应用OSCache,我们不但可以实现通常的Cache功能、自由的设定cache的相关特性比如缓存时间段/缓存内容等,提升系统性能,而且还能有效的改善系统的稳定性。除此之外,OSCache组件还提供了更多的特性比如集群、容错、灵活的缓存区选择等。 作者根据自己的使用经验给大家提供了一些简单的例子,他们部分演示了如何使用OSCache组件提供的丰富特性,OSCache提供的特性远不止这些,需要大家在今后的时间里深入的研究,同时也希望大家通过E-mail和作者贡献研究成果。
参考资料1. OpenSymphony网站中关于OSCache的部分 http://www.opensymphony.com/oscache/
下载内容1. OSCache下载地址 http://www.opensymphony.com/oscache/download.html