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

OSCache

程序员文章站 2022-04-14 18:05:33
...

 

OSCache使用的三个场景

1.JSP缓存

JSP中使用标签缓存JSP片段,这个特性需要J2EE应用服务器的支撑。

2.Request缓存

使用Filter缓存整个HTTP响应

3.一般目的缓存

直接调用OSCache  API完成普通Java对象的缓存,你可以更直接地控制缓存

缓存的对象保存在什么地方

一般而言,缓存对象可以保存在内存和(/或)硬盘中,你也可以通过定制持久实现和事件处理方法,来实现缓存对象保存在其他位置如DatabaseLADP directory

是否可以限制被缓存对象的大小

可以指定被缓存对象的个数,但对于是否可以指定被缓存对象的内存开销还不确定

OSCache缓存替换策略

默认三种替换策略:LRU FIFO Unlimited

也可以自定时缓存替换策略实现类

OSCache集群原理

事件监听+清空事件广播

OSCache安装

必需的文件包括:

oscache.jar

oscache.properties

common-logging.jar

OSCache配置说明

计数|参数名|含义(Meaning)|可取值(Value) |默认值(DefaultValue)|备注(Remark)

 01 | cache.memory | 是否使用内存缓存(M) | true或false(V) | true(DV) | 注释掉该选项表示不使用任何缓存[包括内存或硬盘缓存](R)

02 | cache.capacity | 缓存的最大元素个数(M)| | 不限制(DV) |不提供值或负数均表示不限制(R)

03 | cache.algorithm | 缓存更新策略(M)| com.opensymphony.oscache.base.algorithm.LRUCache
com.opensymphony.oscache.base.algorithm.FIFOCache
com.opensymphony.oscache.base.algorithm.UnlimitedCache (V)| <参考备注>(DV) |当不指定cache.capacity时表示不更新;当指定时默认时LRU缓存更新策略(R)

04 | cache.blocking | 是否同步控制(M) | true或false(V) | false(DV) | 同步会降低效率(R)

05 | cache.unlimited.disk | 指定硬盘缓存是否要作限制(M)|(V) | 不限制(DV) | false的状况下,disk cache capacity 和cache.capacity的值相同(R)

06 | cache.persistence.class  | 指定负责缓存的实现类。class必须实现PersistenceListener接口。作为硬盘持久,可以实现com.opensymphony.oscache.plugins.diskpersistence.HashDiskPersistenceListener接口。
它把class的toString()输出的hash值作为文件的名称。如果你要想文件名易读些(自己设定),DiskPersistenceListener 的父类也能使用,但其可能有非法字符或者过长的名字。(M) | (V) | (DV) |HashDiskPersistenceListener 和 DiskPersistenceListener 需要设定硬盘路径:cache.path (R)

07 | cache.path | 指定硬盘缓存的路径(M) | (V) | (DV) | 目录如果不存在将被建立。同时注意oscache应该要有权限写文件系统。例:cache.path=c:\\myapp\\cache   or *ix: cache.path=/opt/myapp/cache(R)

08 | cache.persistence.overflow.only[Since 2.1] | 是否只有在内存不足的情况下才使用硬盘缓存(M) | true或false(V) | false(DV) | (R)

09 | cache.event.listeners | 缓存事件监听器(M) | (V) | (DV) | 可以不指定或指定多个,指定多个时用逗号隔开;指定的类应实现以下的一个或多个接口:CacheEntryEventListener:接收cache add/update/flush and remove事件CacheMapAccessEventListener :接收cache访问事件(R)

10 | cache.key | 在application 和 session的作用域时 用于标识cache 对象的,  用于ServletCacheAdministrator;(M) | (V) | (DV) | "__oscache_cache",可以通过com.opensymphony.oscache.base.Const.DEFAULT_CACHE_KEY来取得;(R)

11 | cache.use.host.domain.in.key | 当你的服务器被配置为多个host时[可以理解是一个工程配置多个域名],是否自动为每一个cache.key添加host名称信息(M) | true或false(V) | false(DV) | (R)

12 | cache.cluster.multicast.ip | 缓存集群的广播IP地址(M) | (V) | (DV) | (R)

13 | cache.cluster.properties | 缓存集群属性配置(M) | (V) | (DV) | (R)

  • OSCache.zip (5.6 KB)
  • 描述: OSCache介绍Word版
  • 下载次数: 28
相关标签: OSCache