欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

OSCache使用总结

程序员文章站 2022-04-14 17:56:21
...

1.介绍:

  OSCache是一个广泛采用的高性能的J2EE缓存框架,能用于任何Java应用程序的缓存解决方案,它也是一种开创性的JSP地址标记应用,提供了在现有JSP页面之内实现快速缓冲功能。

2.特点:

   可以缓存任何对象,不受限制的的缓存部分JSP页面或者HTTP请求。

   永久缓存,缓存能随意的写入硬盘或者数据库

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

   缓存的有效期,可以最大限度的控制缓存对象的过期,包括可插入式刷新策略

3.配置:

  cache.memory:值为true或false,默认为用内存作为缓存(如果设置为false,那么擦车只能缓存到硬盘或数据库中)

   cache.capacity:缓存元素个数

   cache.persistenece.class:持久化缓存类,如此类打开,必须修改oscache.properties中的cache.path信息(win系统类路径类似为c:\\web\\cacheinfo,unix系统类路径类似为/opt/web/cacheinfo)

   cache.cluster 设置集群相关信息,如:cache.cluster.multicast.ip为广播IP地址,cache.cluster.properties为集群属性

4.缓存过滤

    在web.xml中定义缓存过滤器,定义缓存特定资源(cacheFilte只捕获http头为200的页面请求)

5.oscache和hashmap的比较:

   在多线程环境中oscache比hashmap的并发性好,hashmap是对整个hashmap加锁,而oscache是对各个缓存对象更新加锁

  oscache的cache是由并发读,互斥写机制实现的,可以失效读的并发,但不支持并发写,jdk1.5下的concurrentHashMap是支持并发读和并发写的一个map,其性能会更高

6.oscache主要有三类操作(getFromCache,putInCache,removeEntry):

    第一次调用getFromCache会抛异常,抛异常的时候标示需要更新缓存(putInCache),而且一定要对缓存更新或者取消更新,否则会占用缓存对象的锁,其他线程调用getFromCache的时候会被阻塞,更新缓存的时候调用putInCache,如果失败则调用cancelUpdate,否则也会阻塞其他线程,其中更新缓存状态的方法有cancelUpdate,completeUpdate,putInCache执行成功则会调用completeUpdate,否则应该调用cancelUpdate,而且getFromCache方法在缓存失效是会执行startUpdate也会改变缓存状态,这时需要调用cancelUpdate或者putInCache。

7.用到的jar包:

      <dependency>

          <groupId>opensymphony</groupId>

          <artifactId>oscache</artifactId>

          <version>2.4.1</version>

        </dependency>

       <dependency>

            <groupId>commons-logging</groupId>

            <artifactId>commons-logging</artifactId>

            <version>1.1.3</version>

       </dependency>

        <dependency>

            <groupId>log4j</groupId>

            <artifactId>log4j</artifactId>

            <version>1.2.17</version>

       </dependency>

8.示例如下:

public class OSCacheUtils{

private GeneralCacheAdministrator cacheAdmin;

//获取缓存信息

    public String getCacheInfo() {

// 加入oscache缓存,缓存的有效期是5分钟

try {

if (cacheAdmin == null) {

cacheAdmin = new GeneralCacheAdministrator();

}

Object result = cacheAdmin.getFromCache("mykey",

5 * 60);

if (result != null) {

return result.toString();

}

} catch (NeedsRefreshException e) {

try {

String str ="make your uncomfortable";

cacheAdmin.putInCache("mykey", str);

return str;

} catch (IOException e1) {

logger.error("error", e1);

}

} catch (Exception ex) {

cacheAdmin.cancelUpdate("mykey");

logger.error("error", ex);

}

return "error";

}

}

 

 

   

 

相关标签: oscache 缓存