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 为集群属性