Ehcache使用用例

Ehcache使用用例(一)

Singleton创建方式

Java代码

  1. //Ehcache1.2版本之后,都可以使用singleton(工厂创建方法)去创建一个singleton的CacheManager实例。   
  2.   
  3. CacheManager.create();   
  4. String[] cacheNames = CacheManager.getInstance().getCacheNames();   
  5.   
  6. //使用默认配置创建CacheManager   
  7.   
  8. CacheManager manager = new CacheManager();   
  9. String[] cacheNames = manager.getCacheNames();   
  10.   
  11. //使用配置文件创建指定的CacheManager   
  12.   
  13. CacheManager manager1 = new CacheManager(“src/config/ehcache1.xml”);   
  14. CacheManager manager2 = new CacheManager(“src/config/ehcache2.xml”);   
  15. String[] cacheNamesForManager1 = manager1.getCacheNames();   
  16. String[] cacheNamesForManager2 = manager2.getCacheNames();  


配置文件加载方式

Java代码

  1. CacheManager manager = new CacheManager();//会在classpath路径下找ehcache.xml配置文件。   
  2.   
  3. CacheManager manager = new CacheManager(“src/config.ehcache.xml”); //也可以根据相对文件路径来加载配置文件.   
  4.   
  5. //通过URL加载   
  6.   
  7. URL url = getClass().getResource(“/anotherconfigurationname.xml”);   
  8. CacheManager manager = new CacheManager(url);   
  9.   
  10. //通过流加载   
  11.   
  12. InputSream fis = new FileInputStream(new File(“src/config/ehcache.xml”).getAbsolutePath());   
  13. Try {   
  14. CacheManager manager = new CacheManager(fis);   
  15. } finally {   
  16. Fis.close();   
  17. }   


编码实现添加和缓存

Java代码

  1. //Ehcache中不仅可以用配置文件来配置缓存,而在代码中也可以实现同样的功能。   
  2.   
  3. CacheManager singletonManager = CacheManager.create();   
  4. Cache memoryOnlyCache = new Cache(“testCache”, 50000, false, false, 8, 2);   
  5. Cache test = singletonManager.getCache(“testCache”);   
  6.   
  7. //删除只需要调用   
  8. singletonManager.removeCache(“testCache”);  

Shotdown CacheManager

在使用完Ehcache后,必须要shutdown缓存。Ehcache中有自己的关闭机制,不过最好在你的代码中显示调用CacheManager.getInstance().shutdown();

Ehcache使用实例(二)

Cache使用
l 得到一个Cache引用

获得一个sampleCache1的引用,从官方下载ehcache.xml,在ehcache.xml中已经有配置好的缓存,大家直接使用就可以,或是做测试,如果说真正使用的时候,最后自己手动配置一个比较好。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);  

l 使用Cache

Put一个Element到cache中

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Element element = new Element(“key1”,”value1”);   
  3. cache.put(element);  

update一个element时,只要在构造element时将相同的key传入,在调用cache.put(element),这是Ehcache会根据key到缓存中找到对应的element并做更新。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Cache.put(new Element(“key1”, “value1”));   
  3. //更新element   
  4. Cache.put(new Element(“key1”, “value2”));  

根据key取得对应element的序列化value值

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Element element = cache.get(“key1”);   
  3. Serializable value = element.getValue();  

根据key取得对应element的非序列化value值

Java代码

  1. Cache cache = manager.getcache(“samplecache1”);   
  2. Element element = cache.get(“key1”);   
  3. Ojbect value = element.getObjectValue();  

从cache中移除key对应的element

Java代码

  1. Cache cache = manager.getCache(“sampleCache”);   
  2. Element element = new Element(“key1”, “value1”);   
  3. Cache.reomve(“key1”);  

l 磁盘持久化

SampleCache1的配置是支持磁盘持久化的。如果想要保证element即时的被输出到磁盘,可以调用cache.flush();

Java代码

  1. Cache cache = manager.getcache(“samplecache1”);   
  2. Cache.flush();  

l Cache Sizes

获得当前cache中的element数量。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Int elementsInMemory = cache.getSize();  

获得当前MemoryStore中的element数量。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. long elementsInMemory = cache.getMemoryStoreSize();  

获得当前DiskStore中element数量。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. long elementsInMemory = cache.getDiskStoreSize();  

l Cache Hits and Misses

所谓的hits就是缓存访问次数,而misses就是缓存中每个element的丢失次数。这些参数对优化缓存配置有很大的帮助。

获得缓存中请求的element被找到的次数。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Int hits = cache.getHitCount();  

获得请求的element在MemoryStore中被找到的次数。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Int hits = cache.getMemoryStoreHitCount();  

获得请求的element在DiskStore中被找到的次数。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Int hits = cache.getDiskStoreHitCount();   

获得请求的element在MemoryStore中没有被找到的次数。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Int hits = cache.getMissCountNotFound();   

获得请求的element在MemoryStore中没有被找到的次数。

Java代码

  1. Cache cache = manager.getCache(“sampleCache1”);   
  2. Int hits = cache.getMissCountNotFound();  

获得缓存中失效element没有被找到的次数。

Java代码

  1. Cache cache = manager.getcache(“samplecache1”);   
  2. Int hits = cache.getMissCountExpired();  


创建一个默认配置cache
manager.addCache(String cachename);这个方法可以说是Ehcache很灵活的体现,通常我们想要添加一个新的cache到CacheManager中时,应该调用 manager.addCache(Cache cache);可以看到入参是一个Cache类型对象,而前面那段代码,Ehcache会自动使用默认配置创建一个名字为输出参数的cache供使用,是 不是很方面呢。

使用自定义参数创建一个cache
Ehcache允许通过编码的方式创建一个自定义Cache,也就是调用构造方法。

Java代码

  1. PublicCache(String name, int maxElementsInMemory, MemoryStoreEvictionPolicymemoryStoreEvictionPolicy, Boolean overflowToDisk, Boolean eternal,long timeToLiveSeconds, long timeToIdleSeconds, Boolean isdkPersistent,long diskExpiryThreadIntervalSeconds) {}   
  2.   
  3. //以上就是Cache的构造函数。   
  4. CacheManager manager = CacheManager.create();   
  5. Cache cache = new Cache(“test”, maxElements, MemoryStoreEvictionPolicy.LFU, true, false, 60, 30, false, 0);   
  6. Manager.addCache(testCache);  

以 上代码是创建一个缓存添加到cachemanager中,缓存名字为test,内存驱逐策略是LFU,允许输出到磁盘,element不是永久有效 的,element最大存活时间是60秒,element最大闲置时间30秒,不会持久化到磁盘,失效element清理线程运行时间间隔是0秒。

Ehcache使用实例(三)

   注: 跟笔者其它研究源码的博客一样, Ehcache系列也是基于一个例子来debug地跟踪, 例子详见Ehcache(一): Spring + Ehcache开场白中的附件.如果没有例子作参照,阅读过程中可能有些摸不着头绪.
------------------------------
   
Ehcache(二): 从EhCacheManagerFactoryBean说起中, 我们看到一个EhCacheManagerFactoryBean的创建并由此启用一个CacheManager实例.结合ehcache的配置文件和 CacheManager的名字,不难猜出这个实例是管理Cache的.那么这个CacheManager实例用在了哪?配置文件中的 org.springframework.cache.ehcache.EhCacheFactoryBean实例的创建中.那么又用这个 CacheManager实例做了些什么呢?这得看EhCacheFactoryBean类的afterPropertiesSet方法. 

    方法afterPropertiesSet中有这么一段代码:        

Java代码

  1. if (this.cacheManager.cacheExists(this.cacheName)) {   
  2.             if (logger.isDebugEnabled()) {   
  3.                  logger.debug("Using existing EHCache cache region '" + this.cacheName + "'");   
  4.              }   
  5.             this.cache = this.cacheManager.getEhcache(this.cacheName);   
  6.          }   

    也就是说, cacheManager会检查下配置的cacheName(即,ehcache.xml文件中名为com.rmn190.MethodCache的cache)对应的cache是否已经存在. 如果存在,就直接get出来. 

    这只是get了下cacheManager中已有的cache,那么那个已有的cache是怎么创建出来的? 也就是本例中的名为com.rmn190.MethodCache的cache的cache是何时/如何创建的? 

    一番顺藤模瓜后, 找到了ConfigurationHelper类中的createCache(CacheConfiguration cacheConfiguration)方法. 这里真真切切地看到了"new Cache"的调用.

    上面我们深层次地体会到Cache实例的创建并通过cacheManager给get了出来,get出来后,在Spring中就set给了例子中 MethodCacheInterceptor类属性cache. 不过这里又有问题了:MethodCacheInterceptor类属性cache是一net.sf.ehcache.Cache类型的,但 Spring配置文件中set来的实例是一个 org.springframework.cache.ehcache.EhCacheFactoryBean,类型不匹配 的,EhCacheFactoryBean与Cache有继承或实现关系? 看源码,没有发现. 那Spring又是怎么解决这个类型不匹配问题的? 

    我们在EhCacheFactoryBean类实现的接口FactoryBean上找到了答案: getObject和getObjectType. 通过FactoryBean接口定义两个方法给出的信息,Spring就很自然而流畅地解决了类型匹配问题.

From:http://wangji.jsphostcn.net/data/read/9082712050576.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然,我可以为您提供关于 Ehcache 的详细教程。以下是使用 Ehcache 的一般步骤: 1. 引入 Ehcache 依赖:在您的项目中,您需要添加 Ehcache 的依赖。可以使用 Maven 或 Gradle 进行管理。以下是 Maven 的配置示例: ```xml <dependency> <groupId>org.ehcache</groupId> <artifactId>ehcache</artifactId> <version>3.8.1</version> </dependency> ``` 2. 创建一个 Ehcache 配置文件:Ehcache 使用 XML 文件来配置缓存。您可以创建一个名为 `ehcache.xml` 的文件,并将其放置在类路径下。以下是一个简单的配置示例: ```xml <config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.ehcache.org/v3" xsi:schemaLocation="http://www.ehcache.org/v3 http://www.ehcache.org/schema/ehcache-core.xsd"> <cache alias="myCache"> <resources> <heap unit="entries">100</heap> <offheap unit="MB">1</offheap> </resources> </cache> </config> ``` 3. 初始化和获取缓存:在您的代码中,您需要初始化 Ehcache 缓存管理器,并获取所需的缓存实例。以下是示例代码: ```java import org.ehcache.Cache; import org.ehcache.CacheManager; import org.ehcache.config.builders.CacheConfigurationBuilder; import org.ehcache.config.builders.CacheManagerBuilder; import org.ehcache.xml.XmlConfiguration; public class Main { public static void main(String[] args) { XmlConfiguration xmlConfig = new XmlConfiguration(Main.class.getResource("/ehcache.xml")); CacheManager cacheManager = CacheManagerBuilder.newCacheManager(xmlConfig); cacheManager.init(); Cache<String, String> myCache = cacheManager.getCache("myCache", String.class, String.class); myCache.put("key", "value"); String value = myCache.get("key"); System.out.println(value); cacheManager.close(); } } ``` 在上面的示例中,我们首先使用 `XmlConfiguration` 类将 XML 配置文件加载为 `CacheManagerBuilder`。然后,我们使用 `cacheManager` 获取名为 "myCache" 的缓存实例,并将键值对放入缓存。最后,我们从缓存中获取值并打印出来。 这是一个简单的 Ehcache 使用教程。您可以根据自己的需求进行更高级和复杂的配置。希望对您有所帮助!如有任何问题,请随时向我提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值