主流Cache配置项介绍
一、EHCache: ehcahe.xml
1、diskStore:
配置DiskStore,当需要使用磁盘保存的时候,需要对象实现序列化接口
属性:path 配置文件存储位置
2、cacheManagerEventListenerFactory :
指定 CacheManagerEventListenerFactory,
用于创建CacheManagerPeerProvider
提醒当CacheManager中的缓存增加或者删除操作
属性:class:完整的工厂类名称,properties:逗号分割的属性
3、cacheManagerPeerProviderFactory:
指定CacheManagerPeerProviderFactory,
用于创建 CacheManagerPeerProvider,用于在cluster中查找CacheManagers。
属性:class:完整的工厂类名称,properties:逗号分割的属性
4、cacheManagerPeerListenerFactory:
指定CacheManagerPeerListenerFactory,
用于创建CacheManagerPeerListener,监听cluster中的复制信息
属性:class:完整的工厂类名称,properties:逗号分割的属性
5、defaultCache|cache
必须属性:
name:设置缓存的名称,用于标志缓存,惟一
maxElementsInMemory:在内存中最大的对象数量
maxElementsOnDisk:在DiskStore中的最大对象数量,如为0,则没有限制
eternal:设置元素是否永久的,如果为永久,则timeout忽略
overflowToDisk:是否当memory中的数量达到限制后,保存到Disk
可选的属性:
timeToIdleSeconds:设置元素过期前的空闲时间
timeToLiveSeconds:设置元素过期前的活动时间
diskPersistent:是否disk store在虚拟机启动时持久化。默认为false
diskExpiryThreadIntervalSeconds:运行disk终结线程的时间,默认为120秒
memoryStoreEvictionPolicy:策略关于Eviction
子元素:
cacheEventListenerFactory:
注册相应的的缓存监听类,用于处理缓存事件。如put,remove和expire
bootstrapCacheLoaderFactory:
指定相应的BootstrapCacheLoader,用于在初始化缓存,以及自动设置。
6、cacheExceptionHandlerFactory:
产生异常时设置。
属性:class:完整的工厂类名称,properties:逗号分割的属性
二、OSCache:oscache.properties
1、cache.memory:
是否使用内存缓存; true 或 false。默认为true;
2、cache.capacity:
缓存的最大数量。默认是不限制,cache不会移走任何缓存内容。
3、cache.algorithm:
运算规则--最后插入的最先调用,最先插入的最先调用,永远不会被丢弃。
4、cache.blocking:
是否同步。true 或者 false。一般设为true,避免读取脏数据。
5、cache.unlimited.disk:
指定硬盘缓存是否要作限制。默认值为false。
6、cache.persistence.class:
指定类是被持久化缓存的类。class必须实现PersistenceListener接口。
7、cache.path:
指定硬盘缓存的路径。
8、cache.persistence.overflow.only:
是否只有当指定的内存缓存已经满时才进行持久化。
9、cache.event.listeners:
一系列用逗号分割的事件监听类。
10、cache.key:
指定在application或session范围里缓存的对象的key。
11、cache.use.host.domain.in.key:
是否在配置多个服务器时,想通过服务器名称自动生成cache key。
12、cache.cluster.multicast.ip:
集群配置IP
13、cache.cluster.properties:
集群中的额外配置项