• oscache缓存技术


    一、OSCache是当前运用最广的缓存方案,JBoss,Hibernate,Spring等都对其有支持,下面简单介绍一下OSCache的配置和使用过程。

    http://www.opensymphony.com/oscache/download.action下载你所需要的oscache版本

    本人使用的版本是oscache-2.4,以下将以此版本作为例子

    1.解压缩下载的文件到指定目录
    从src或etc目录取得oscache.properties 文件,放入src根目录或发布环境的/WEB-INF/classes 目录
    如你需要建立磁盘缓存,须修改oscache.properties 中的cache.path信息 (去掉前面的#注释)。

    拷贝OSCache标签库文件oscache.tld到/WEB-INF/classes目录。

    现在你的应用目录类似如下:
    $WEB_APPLICATIONWEB-INF\lib\oscache.jar
    $WEB_APPLICATIONWEB-INF\classes\oscache.properties
    $WEB_APPLICATIONWEB-INF\classes\oscache.tld


    2.oscache.properties 文件配置向导

    cache.memory
    值为true 或 false ,默认为在内存中作缓存,
    如设置为false,那cache只能缓存到数据库或硬盘中,那cache还有什么意义:)

    cache.capacity
    缓存元素个数

    cache.persistence.class
    持久化缓存类,如此类打开,则必须设置cache.path信息

    cache.cluster 相关
    为集群设置信息。

    cache.cluster.multicast.ip为广播IP地址
    cache.cluster.properties为集群属性

    3.oacache的应用

      jsp页面缓存,cache1.jsp

    写道
    <%@ page contentType="text/html;charset=GBK"%>
    <%@ page import="java.util.*" %>
    <%@ taglib uri="/WEB-INF/oscache.tld" prefix="cache" %>
    <html>
    <body>
    没有缓存的日期: <%= new Date() %><p>
    <!--自动刷新-->
    <cache:cache time="30">
    每30秒刷新缓存一次的日期: <%= new Date() %>
    </cache:cache>
    <!--手动刷新-->
    <cache:cache key="testcache">
    手动刷新缓存的日期: <%= new Date() %> <p>
    </cache:cache>
    <a href="cache2.jsp">手动刷新</a>
    </body>
    </html>

     cache2.jsp

    Java代码 复制代码 收藏代码
    1. <%@ page contentType="text/html;charset=GBK"%>   
    2. <%@ taglib uri="/WEB-INF/oscache.tld" prefix="cache" %>   
    3. <html>   
    4. <body>   
    5.   
    6. 缓存已刷新...<p>   
    7.   
    8. <cache:flush key="testcache" scope="application"/>   
    9.   
    10. <a href="cache1.jsp">返回</a>   
    11.   
    12. </body>   
    13. </html>  
    <%@ page contentType="text/html;charset=GBK"%>
    <%@ taglib uri="/WEB-INF/oscache.tld" prefix="cache" %>
    <html>
    <body>
    
    缓存已刷新...<p>
    
    <cache:flush key="testcache" scope="application"/>
    
    <a href="cache1.jsp">返回</a>
    
    </body>
    </html>

      过滤器缓存

    web.xml

    Xml代码 复制代码 收藏代码
    1. <filter>    
    2.     <filter-name>CacheFilter</filter-name>    
    3.     <filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class>    
    4.     <init-param>    
    5.     <param-name>time</param-name>    
    6.     <param-value>3600</param-value>    
    7.     </init-param>    
    8.     <init-param>    
    9.     <param-name>scope</param-name>    
    10.     <param-value>session</param-value>    
    11.     </init-param>    
    12. </filter>     
    13. <filter-mapping>    
    14.     <filter-name>CacheFilter</filter-name>    
    15.     <url-pattern>/selectedUser4UserPopupSelect.do</url-pattern>    
    16. </filter-mapping>  
    17. <filter-mapping>    
    18.     <filter-name>CacheFilter</filter-name>    
    19.     <url-pattern>/userPopupSelector.do</url-pattern>    
    20. </filter-mapping>    
    21. <filter-mapping>    
    22.     <filter-name>CacheFilter</filter-name>    
    23.     <url-pattern>/selectedUserFrame4UserPopupSelect.do</url-pattern>    
    24. </filter-mapping>    
    25. <filter-mapping>    
    26.     <filter-name>CacheFilter</filter-name>    
    27.     <url-pattern>/listUserFrame4UserPopupSelect.do</url-pattern>    
    28. </filter-mapping>    
    29. <filter-mapping>    
    30.     <filter-name>CacheFilter</filter-name>    
    31.     <url-pattern>/listUser4PopupSelect.do</url-pattern>    
    32. </filter-mapping>    
    33. <filter-mapping>    
    34.     <filter-name>CacheFilter</filter-name>    
    35.     <url-pattern>/popupAllOrganizationTree.do</url-pattern>    
    36. </filter-mapping>    
    37. <filter-mapping>    
    38.     <filter-name>CacheFilter</filter-name>    
    39.     <url-pattern>/index.do</url-pattern>    
    40. </filter-mapping>    
    41. <filter>    
    42.     <filter-name>osCacheFilter</filter-name>    
    43.     <filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class>    
    44.     <init-param>    
    45.     <param-name>time</param-name>    
    46.     <param-value>3600</param-value>    
    47.     </init-param>    
    48.     <init-param>    
    49.     <param-name>scope</param-name>    
    50.     <param-value>application</param-value>    
    51.     </init-param>    
    52. </filter>     
    53. <filter-mapping>    
    54.     <filter-name>osCacheFilter</filter-name>    
    55.     <url-pattern>/listBig4Entity.do</url-pattern>    
    56. </filter-mapping>  
    57. <filter-mapping>    
    58.     <filter-name>osCacheFilter</filter-name>    
    59.     <url-pattern>/listSubEntity4Index.do</url-pattern>    
    60. </filter-mapping>   
     <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>3600</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> 
    		<url-pattern>/selectedUser4UserPopupSelect.do</url-pattern> 
    	</filter-mapping>
    	<filter-mapping> 
    		<filter-name>CacheFilter</filter-name> 
    		<url-pattern>/userPopupSelector.do</url-pattern> 
    	</filter-mapping> 
    	<filter-mapping> 
    		<filter-name>CacheFilter</filter-name> 
    		<url-pattern>/selectedUserFrame4UserPopupSelect.do</url-pattern> 
    	</filter-mapping> 
    	<filter-mapping> 
    		<filter-name>CacheFilter</filter-name> 
    		<url-pattern>/listUserFrame4UserPopupSelect.do</url-pattern> 
    	</filter-mapping> 
    	<filter-mapping> 
    		<filter-name>CacheFilter</filter-name> 
    		<url-pattern>/listUser4PopupSelect.do</url-pattern> 
    	</filter-mapping> 
    	<filter-mapping> 
    		<filter-name>CacheFilter</filter-name> 
    		<url-pattern>/popupAllOrganizationTree.do</url-pattern> 
    	</filter-mapping> 
    	<filter-mapping> 
    		<filter-name>CacheFilter</filter-name> 
    		<url-pattern>/index.do</url-pattern> 
    	</filter-mapping> 
    	<filter> 
    		<filter-name>osCacheFilter</filter-name> 
    		<filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class> 
    		<init-param> 
    		<param-name>time</param-name> 
    		<param-value>3600</param-value> 
    		</init-param> 
    		<init-param> 
    		<param-name>scope</param-name> 
    		<param-value>application</param-value> 
    		</init-param> 
    	</filter>  
    	<filter-mapping> 
    		<filter-name>osCacheFilter</filter-name> 
    		<url-pattern>/listBig4Entity.do</url-pattern> 
    	</filter-mapping>
    	<filter-mapping> 
    		<filter-name>osCacheFilter</filter-name> 
    		<url-pattern>/listSubEntity4Index.do</url-pattern> 
    	</filter-mapping> 

    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>

  • 相关阅读:
    HDU-5818-Joint Stacks
    蓝桥杯-2016CC-卡片换位
    HDU-2255-奔小康赚大钱(KM算法)
    蓝桥杯-PREV31-小朋友排队
    crypto.js加密传输
    js之对象
    LigerUi之ligerMenu 右键菜单
    关于js中window.location.href,location.href,parent.location.href,top.location.href的用法
    设置js的ctx
    AngularJS简单例子
  • 原文地址:https://www.cnblogs.com/firstdream/p/2406268.html
Copyright © 2020-2023  润新知