OSCache 缓存解决方案

OSCache 缓存解决方案

1. OSCache 是什么?

    OSCache 标记库由 OpenSymphony 设计,它是一种开创性的缓存方案,

    它提供了在现有JSP 页面之内实现内存缓存的功能。OSCache 是个一个被广泛采用的、

    高性能的 J2EE 缓存框架,OSCache 还能应用于任何 Java 应用程序的普通的缓存解决方案。

2. OSCache 的特点

    a)  缓存任何对象:

         你可以不受限制的缓存部分 jsp 页面或 HTTP 请求,任何 java 对象都可以缓存。

    b)  拥有全面的 API:

         OSCache API 允许你通过编程的方式来控制所有的 OSCache 特性。

    c)  永久缓存:

         缓存能被配置写入硬盘,因此允许在应用服务器的多次生命周期间缓存创建开销昂贵的数据。

    d)  支持集群:

         集群缓存数据能被单个的进行参数配置,不需要修改代码。

    e)  缓存过期:

         你可以有最大限度的控制缓存对象的过期,包括可插入式的刷新策略(如果默认性能

         不能满足需要时)。

3. OSCache 的安装与配置

    a)  首先打开:http://java.net/downloads/oscache/下载最新版本的 OSCache,

         本次使用的版本是 2.4.1,暂时为最新版本。

    b)  将 oscache-2.4.1-full.zip 解压,如下图所示


 

    c)  解压后,将 oscache-2.4.1.jar、lib 目录里的 commons-logging.jar 一同放进你自己

         应用的 WEB-INF/lib 里,如果有原来有 commons-logging.jar,那么不要重复添加。

    d)  将 etc 目录下的 oscache.properties、oscache.tld 这 2 个文件放入你自己应用的

         /WEB-INF/classes 目录。开发阶段,我们可以把该文件放置在 src 目录下即可。

    e)  在你自己应用的 web.xml 里面添加配置信息,

         添加代码如下:

<jsp-config>
    <taglib>
        <taglib-uri>oscache</taglib-uri>
        <taglib-location>/WEB-INF/classes/oscache.tld</taglib-location>
    </taglib>
</jsp-config>

    现在我们就可以使用 OSCache 了。

4. OSCache 页面局部缓存

    a)  引入标签

         i.   <%@ taglib uri="oscache" prefix="cache" %>(在 src下放置了 oscache.tld文件)

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

            (在 src 下没有放置了 oscache.tld 文件)

    b)  标签用法

         i.   最简单的用法

<cache:cache>
    <%
        Syste.out.println("Test OSCache! ");
    %>
</cache:cache>

    缓存的key将以请求的URI+ 查 询 字 串 组 成 ,如果你访问

    /oscache/index.jsp?name=ttt 和/oscache/index.jsp?name=ppp 将得到两份缓存。

    缓存默认存放在 application 范围,缓存时间默认为 3600 秒,即 1 小时。

          ii.  指定缓存 key

<oscache:cache key="name">
    name=${param.name}
</oscache:cache>

    这时候缓存将以 name 为 key,不再是请求的 URI+查询字串组成,所以如果你访问

    /oscache/index.jsp?name=ttt 和/oscache/index.jsp?name=ppp 将得到一份缓存。

          iii. 指定缓存作用域

<oscache:cache key="name" scope="session">
    name=${param.name}
</oscache:cache>

    缓存范围设置为 session,这时候缓存保存在用户的 session 中,如果用户的把浏览器关闭,

    再重新打开一个新浏览器,原来缓存的内容将不存在。

 

          iv. 为缓存设置时间

<oscache:cache key="name" time="10">
    name=${param.name}
</oscache:cache>

   上面设置了缓存的时间为 10 秒,超过 10 秒后,缓存的内容将失掉。

    如此处时间为-1 则被缓存的内容永不过期。

 

          v.   通过 cron 表达式来设定缓存方案

<cache:cache key="first" cron="0 2 * * *" >
    <%
        //通过 Cron 表达式指定每天的早上 2 点钟缓存的内容失效
    %>
</cache:cache>

    详细请参考 cron 表达式

 

          vi.  清除缓存

<oscache:cache key="name" time="60" refresh="${param.refresh}">
    name=${param.name}
</oscache:cache>

    refresh 为 true 将会导致缓存的内容过期而被清除,简单地说,

    该属性为 true 用于清除缓存。

 

          vii. 人为管理缓存<flush />标签

<oscache:flush scope="application" />

    清除 application 范围内的所有缓存

 

<oscache:flush scope="session" key="foobar" />

    清除 session 范围内的 key 为 foobar 的缓存。

 

<oscache:flush scope="application" group="currencyData" />

    清除 application 范围内组名为 currencyData 内的所有缓存。

 

5. OSCache 页面全部缓存

    a)  页面缓存过滤器 代码如下:

<filter>
    <filter-name>cacheFilter</filter-name>
    <filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-c
lass>
    <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>

   

    b)  配置你需要缓存的 url 地址 代码如下所示:

<filter-mapping>
    <filter-name>cacheFilter</filter-name>
    <url-pattern>/index/*</url-pattern>
</filter-mapping>
<filter-mapping>
    <filter-name>cacheFilter</filter-name>
    <url-pattern>/index_grounp/*</url-pattern>
</filter-mapping>

6. OSCache 的配置文件属性介绍(oscache.properties)

    a)  cache.memory=true

         指定是否使用内存缓存,默认值为 true,即使用内存缓存。

         如果设置为 false,那 cache 只能缓存到数据库或硬盘中,那 cache 还有什么意义。

    b)  cache.capacity

         指定缓存的容量,默认的容量是无限的。我们可以为它设置缓存数量,

         如:cache.capacity=100000

    c)  如果我们要使用硬盘缓存,可以这样设置:

cache.memory=false
cache.path=d:\\cache (指定,缓存保存的路径,注意:路径应采用双\符)
cache.persistence.class=com.opensymphony.oscache.plugins.diskpersistence.DiskPersistenceListener

    d)  cache.persistence.class

         用于设置持久化类(如此类打开,则必须设置 cache.path 信息)

7. 内容补充

    a)  缓存的key将以请求的URI+ 查询字串组成,如果你访问

         /oscache/index.jsp?name=ttt 和/oscache/index.jsp?name=ppp 将得到两份缓存。

         缓存是在初次访问页面时进行的,后续的请求将会返回缓存中的内容。

         缓存中存放的内容为页面返回给用户的 html 源代码。

    b)  CashFilter 是通过过滤器来缓存一个完整的 JSP 页面或者我们生成的二进 制文件,

         包括生成的图片,EXCEL,WORLD,PDF 等。

    c)  Cron 表达式基本语法

         通过 Cron 表达式我们可以很灵活的设置缓存的失效时间,Cron 表达式包括5个字段,

         分别为 Minute,Hour, DOM(Day Of Month), Month,DOW(Day Of Week)。

         他们顺序地对应了5个位置。当某个位置上的值为*时,表示该位置上的任意时间。

         另外还提供了指定时间的操作符号”-”,”,”,”/”,他们 分别表示一段时间范围,

         具体的时间,以及递增的时间段。下面是几个例子说明一下 Cron 表达式的基本应用,

         有兴趣的也可以查看下OScache 的 doc 文 档。

         i.   “10/20 * * * *”:

              因是第一个位置,并且是一个递增的表达式,所以表达式指定的是每个小时的第 10分钟,

              第 30 分钟,第 50 分钟缓存内容失效。

         ii.  “* 8-18/4 * * *” :

              指定每天早上 8 点到晚上6 点之间,每4 个小时缓存内容失效。 等同于”* 8,12,16* * *”

         iii. “* * * * 1-5″:

              表示每个星期一到星期五内容失效。

    d)  cache.cluster 配置属性

         为集群设置信息 如:

         cache.cluster.multicast.ip 为广播 IP 地址

         cache.cluster.properties 为集群属性

猜你喜欢

转载自iqeq00.iteye.com/blog/2028954