zoukankan      html  css  js  c++  java
  • OScached页面缓存的入门使用

    OSCache的使用:

    一,环境的搭建:

     1,把oscache.jar file放在 /WEB-INF/lib 目录下(Put the oscache.jar file in the /WEB-INF/lib directory)

    2,如果commons-logging.jar文件不存在,也要把它放进/WEB-INF/lib 目录下

    3,把/etc/oscache.properties放进类路径下

    注意:Remember to escape any  characters in Windows paths - e.g. if you want cache files to go in c:cachedir, the cache.path property should be set to c: cachedir.

    二,OSCache 处理一个servlet Filter,使你能够很容易的缓存你网站的整个页面,甚至是二进制数据,二进制文件的缓存非常有用当他们被动态产生。

    配置Filter:

    Example1:时间是10minutes scope: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>

        <url-pattern>*.jsp</url-pattern>

    </filter-mapping>

    Example2:默认缓存的scope是application,时间是一个小时

    <filter>

        <filter-name>CacheFilterStaticContent</filter-name>

        <filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class>

        <init-param>

            <param-name>expires</param-name>

            <param-value>time</param-value>

        </init-param>

    </filter>

    <filter-mapping>

        <filter-name>CacheFilterStaticContent</filter-name>

        <url-pattern>*.jsp</url-pattern>

    </filter-mapping>

    三 标签:

    <%@ taglib uri="http://www.opensymphony.com/oscache" prefix="cache" %>

    主要的标签有:

    · cache- The main caching tag

    · usecached- A nested tag to force using a cached version.

    · flush- To flush caches programmatically.

    · addgroup- It allows a single group name to be dynamically added to a cached block. This tag must be nested inside <cache:cache/>.

    · addgroups- It allows a comma-delimited list of group names to be dynamically added to a cached block. This tag must be nested inside <cache:cache/>.

    1.cache是OSCache主要的标签。根据指定的属性,标签的体将被缓存。以后每次运行标签,它会检查,看看缓存的内容是否过期,如果下列条件成立的话,标签体的内容将被认为是过时的:

       1:标签体的内容超过了指定的缓存时间;默认为一小时,指定时以s为单位。

       2:超多了cron属性指定的日期或时间;

       3:通过flush标签,清除了指定的scope作用域的缓存。

    如果缓存的主体内容是过期的,标签会再次执行和缓存新的主体内容。

    属性:

    ① Key:这应该是为给定的范围内唯一的,因为重复的键映射到相同的缓存条目,因为缓存存放在map集合里面。key的默认值为使用URI转义版本和当前页面的查询字符串(默认值使用的URI转义版本和当前页面的查询字符串)。

    ② scope:缓存存放的作用域,默认为application。可选的值为session和application。

    ③ time:指定缓存存放的时间,以秒为单位,默认为3600s,即一个小时。如果为负值表示永远不过期。

    ④ duration:这是和time属性二选一的。Duration可以通过simple date format指定。

    ⑤ cron:cron表达式确定缓存的内容什么时候过期,它允许缓存的内容在特殊的日期或时间过期,而不是当缓存的内容达到某个年龄。

    介绍cron表达式:cron表达式的语法:

           cron表达式由下面5个字段组成:

    Minute:指定缓存的内容在小时的第几分钟过期,取值范围是0-59;

    Hour:指定缓存的内容在一天的第几个小时将过期,这是指定使用24小时制,因此取值范围是:0(午夜)-23(上午11点)。

    DOM:一个月的第几天。这是一个从1到31的数,它表示缓存的内容什么日子过期,如:在每月的10号过期,应该把值设为10。

    Month:一年的第几月使内容过期,它可以通过数字1-12或者月的英文名字(eg 'January')指定。月的名称对大小写是不敏感的,只考虑前三个字符,其他部分忽略。

    DOW:一周的第几天使缓存的内容过期,它可以是数字(0-6,0=星期天,6=星期六)或者是英文的星期名称。和月份一样大小写是不敏感的,只考虑前三个字符,其他部分忽略。

    注意:当你不想给某个字段给定特定的值,你可以使用"*"代替。

    OSCache的也允许你选择性地指定每个字段内的列表,范围和时间间隔(甚至是三者的结合)

    List:集合中的列表项通过","分隔,缓存过期的时间和每个列表项匹配,例如:"0,15,30,45 * * * *",表示缓存中的内容每隔15分钟过期一次。

    Ranges:使用"-"指定范围。一个范围将包括所有值从开始到结束值(包括起始值)例如: "* * * Jan-June *"表示一年的前六个月缓存将过期。 Intervals:一个间隔通过"/"指定。左边的“/”字符的值表示的出发点或范围值应递增超过,而右边的值表示间隔的时间长度。例如:"10/20 * * * *" 相当于 "10,30,50 * * * *", 而"10-45/20 * * * *" 只匹配过去每个小时的10-30分钟,因为50已经超过了范围。

    ⑥ refresh:布尔值,如为true缓存将被刷新,不管缓存的内容是否过期。使你能决定是否重新缓存内容。

    ⑦ mode:如果把值设置为"silent",将防止标签体被写入到输出流。

    ⑧ groups:用逗号分隔组里面的名称,根据你的需要允许把缓存的条目分组。分组是非常有用的当你的缓存内容依赖应用或数据的其他部分,当这些依赖发生变化,flush相关的组将将导致所有缓存的条目在组中过期。

    假设我们有一个类别的动态清单,我们从数据库中拉,我们也偶尔得到更新,通过调用一个WebService存储外币兑换利率。假设,我们也有一些

    内容,显示有关类别和当前的汇率值的信息。下面缓存缓存主体内容的例子分配给2个缓存组 "currencyData"和"categoryList"。当汇率和类别

    列表发生更新,相关的组将被flush因为这些内容(与任何其他与该组相关的内容)被过期了,然后当页面被访问的时候,再次建立缓存。

    <cache:cache key="<%= product.getId() %>" time="-1" group="currencyData, categories">

             ... display category list ...

             ... display currency information ...

     </cache:cache>

    2,usecached 这个标签内嵌在一个<cache>标签中,表示<cache>标签是否使用cached version

    属性:use:默认值为true,表示使用cached version,这是有用的对于编程式控制缓存。

    例如:

    This is a good example of error tolerance. If an exception occurs, the cached version of this content will be output instead.这是很好的容错例子,当异常发生缓存的内容将不会被输出。

        <cache:cache>

             <% try { %>

             ... some jsp content ...

             <% } catch (Exception e) { %>

                  <cache:usecached />

             <% } %>

        </cache:cache>

    例如:<cache:cache>  

    <%out.print(new Date()); %> 

    <cache:usecached use="true"/>  

      </cache:cache>

    第一次访问的时候页面输出:Missing cached content ,如果接着把use改为false则会输出当前时间,当flush时,时间会改变。接着把use改为true,即使flush,时间也不会改变,它还会使用以前的缓存。

    3,flush 

    这个标签是用来在运行时刷新缓存。这是特别有用,因为它可以将您的网站的管理部分编码,以便管理员可以决定何时刷新缓存。

    属性:

    Scope:这决定哪些范围将被刷新。有效值是“application”,“session”和null。空范围将刷新所有缓存,不论其范围。默认为all。

    Key:当同时指定了key和scope,表示一个缓存条目被标记为flush。当他下次被访问的时候缓存将被refresh。当仅指定了key而没有指定scope这是无效的。

    group :指定一组将导致组中的所有缓存项被flush,如果仅仅指定group没有指定scope这是无效的。

    4,addgroup 必须内嵌在<cache:cache>标签内部,它允许一个组名,动态地添加到缓存的块中,

    这将以key为test1的cache块增加到组group1和group2:

     <cache:cache key="test1">

             <cache:addgroup group="group1" />

             ... some jsp content ...

             <cache:addgroup group="group2" />

             ... some more jsp content ...

        </cache:cache>

    5,addgroups 必须内嵌在<cache:cache>标签内部,

    This will add the cache block with the key 'test1' to groups 'group1' and 'group2'.

        <cache:cache key="test1">

             ... some jsp content ...

             <cache:addgroups groups="group1,group2" />

             ... some jsp content ...

    </cache:cache>

    四 属性文件的配置:

    介绍仅涵盖了OSCache的配置,使用的oscache.properties文件,下面的属性能够被设置在oscache.properties文件中:

    Cache.memory:

    有效值是真的还是假的,默认值为true。如果你想禁用内存缓存,只需要注释掉或删除此行。

    禁用内存和磁盘缓存是可能的,而且相当愚蠢。

    Cache.capacity:

    缓存支持缓存条目的最大数量,默认情况下,容量是无限的。缓存将不会删除任何缓存条目。负的值也将意味着无限容量。

    Cache.algorithm:

    使用默认的缓存算法。请注意,为了使用一种算法,还必须指定缓存的大小,如果未指定缓存的大小,缓存算法将是无限的缓存,而不管这个属性的值,如果你指定了大小,但没有指定算法,所使用的缓存算法将为com.opensymphony.oscache.base.algorithm.LRUCache。

    OSCache的目前带有三种算法:

    com.opensymphony.oscache.base.algorithm.LRUCache --------最近最少使用。这是一个默认值当cache.capacity设置了值。

    com.opensymphony.oscache.base.algorithm.FIFOCache --------先进先出。

    com.opensymphony.oscache.base.algorithm.UnlimitedCache---------添加到缓存中的内容,是绝不会被丢弃的,这是默认值当 cache.capacity属性没有设置值。

    Cache.blocking:

    当一个请求一个过期的缓存条目,它可能被另一个线程正在重建该缓存的过程中。

    此设置指定OSCache如何处理后来的“非重建缓存”的线程。

    默认行为(cache.blocking = FALSE)是把过期内容给后面的线程,直到缓存条目已更新。这提供最佳的性能(仅仅花费稍微过时的数据服务的成本)。

    当阻塞被启用,线程反而会阻塞,直到新的缓存条目准备提供,一旦新的条目放进了缓存中,阻塞的线程将重新启动并给予最新的缓存内容。

    请注意,即使阻塞被禁用,当没有过期的数据可提供,线程将被阻塞直到通过线程把建立缓存的数据放进缓存内。

    Cache.unlimited.disk:

    指示磁盘缓存是否应无限制。默认值是false,在这种情况下,磁盘缓存也可以和内存缓存一样通过 cache.capacity属性设置缓存大小

    Cache.persistence.class:

    指定一个类用于持久化缓存条目。这个样的类必须实现PersistenceListener 接口。OSCache 有一个这样的实现提供了一个基于持久化的文件系统。设置这样的属性给com.opensymphony.oscache.plugins.diskpersistence.HashDiskPersistenceListener类去启用这个实现。你应该可以保存缓存数据使用像JDBC, LDAP. NOTE通过指定你自己的类。这个类的对象的哈希码和toString方法返回的值将被缓存用来生成缓存条目的文件名称。如果你喜欢可读的文件名称,父DiskPersistenceListener可以被使用,但那将产生一个问题,由于非法的文件系统字符和长长的名字。

    注意:HashDiskPersistenceListener和DiskPersistenceListener类需要cache.path的设置,以便知道在哪里可以保存文件到磁盘。

    Cache.path:

    这指定缓存将存储在磁盘上的哪个目录,该目录将被创建,如果它不存在,但是要记住OSCache 必须要有权限往这个路径写内容。避免不同的缓存共享相同的缓存路径,因为OSCache没有被设计来处理这些问题。

    注意:对于windows系统,反斜杠字符“”需要被转义。(反斜杠ackslash ;斜杠/forwardslash)。例如:cache.path=c:\myapp\cache 。

    cache.persistence.overflow.only (NEW! Since 2.1):

    指示的持久性是否应该只发生一次内存缓存容量已达到。为了向后兼容默认值是false,但是推荐值是true当memory.cache被启用。这个属性大大改变了缓存的行为,在保存的缓存中将变的不同,那么内存中有什么。

  • 相关阅读:
    深入浅出WPF-08.Event( 事件)01
    深入浅出WPF-07.Property(属性)
    深入浅出WPF-06.Binding(绑定)03
    深入浅出WPF-06.Binding(绑定)02
    深入浅出WPF-06.Binding(绑定)01
    常用快递电子面单账户申请详解(顺丰、中通、圆通、申通、百世、韵达)
    快递鸟电子面单批量打印以及模板设置
    快递公司电子面单怎么申请充值单号(中通、圆通、申通、韵达、百世)
    不限量的快递鸟单号查询接口-JAVA对接方法
    快递单号识别查询api接口调用对接demo
  • 原文地址:https://www.cnblogs.com/sbj-dawn/p/7841390.html
Copyright © 2011-2022 走看看