OSCache缓存
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包: ```
#### 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”; } } ```