EhCache看这一篇就够了

一、简介

EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点。EhCache支持单机缓存和分布式缓存,分布式可以理解为缓存数据的共享,这就导致内存缓存数据量偏小。ehcache缓存非常存储和读取非常快。

主要优点有:

  1. 快速
  2. 简单
  3. 多种缓存策略 堆缓存、磁盘缓存、集群缓存
  4. 缓存数据有两级:,因此无需担心容量问题
  5. 缓存数据会在虚拟机重启的过程中写入磁盘
  6. 可以通过RMI、可插入API等方式进行分布式缓存
  7. 具有缓存和缓存管理器的侦听接口
  8. 支持多缓存管理器实例,以及一个实例的多个缓存区域
  9. 提供Hibernate的缓存实现

二、详细配置

1、引入依赖

net.sf.ehcache ehcache 2.10.4

2、新建配置文件 ehcache.xml

<?xml version="1.0" encoding="UTF-8"?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd">
   <!-- 
         磁盘存储:将缓存中暂时不使用的对象,转移到硬盘,类似于Windows系统的虚拟内存
          path:指定在硬盘上存储对象的路径
   -->
  <!-- 磁盘缓存位置 -->
  <diskStore path="java.io.tmpdir/ehcache"/>
 <!-- 
        defaultCache:默认的缓存配置信息,如果不加特殊说明,则所有对象按照此配置项处理
   -->
  <!-- 默认缓存 -->
  <defaultCache
          maxEntriesLocalHeap="10000"
          eternal="false"
          timeToIdleSeconds="120"
          timeToLiveSeconds="120"
          maxEntriesLocalDisk="10000000"
          diskExpiryThreadIntervalSeconds="120"
          memoryStoreEvictionPolicy="LRU">
    <persistence strategy="localTempSwap"/>
  </defaultCache>
 <!-- 	
 				各个熟悉的含义
 				name 缓存空间名称(非缓存key)
        maxElementsInMemory:设置了缓存的上限,最多存储多少个记录对象
				maxElementsOnDisk:硬盘中最大缓存对象数,若是0表示无穷大
				eternal:true表示对象永不过期,此时会忽略timeToIdleSeconds和timeToLiveSeconds属性,默认为false  
				overflowToDisk:true表示当内存缓存的对象数目达到了maxElementsInMemory界限后,会把溢出的对象写到硬盘缓存中。注意:如果缓存的对象要写入到硬盘中的话,则该对象必须实现了Serializable接口才行。
				diskSpoolBufferSizeMB:磁盘缓存区大小,默认为30MB。每个Cache都应该有自己的一个缓存区。  
				diskPersistent:是否缓存虚拟机重启期数据,设置成true表示缓存虚拟机重启期数据  
				diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认为120秒 
				timeToIdleSeconds: 设定允许对象处于空闲状态的最长时间,以秒为单位。当对象自从最近一次被访问后,如果处于空闲状态的时间超过了timeToIdleSeconds属性值,这个对象就会过期,EHCache将把它从缓存中清空。只有当eternal属性为false,该属性才有效。如果该属性值为0,则表示对象可以无限期地处于空闲状态 
				timeToLiveSeconds:设定对象允许存在于缓存中的最长时间,以秒为单位。当对象自从被存放到缓存中后,如果处于缓存中的时间超过了 timeToLiveSeconds属性值,这个对象就会过期,EHCache将把它从缓存中清除。只有当eternal属性为false,该属性才有效。如果该属性值为0,则表示对象可以无限期地存在于缓存中。timeToLiveSeconds必须大于timeToIdleSeconds属性,才有意义  

    		memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。可选策略有:LRU(最近最少使用,默认策略)、FIFO(先进先出)、LFU(最少访问次数)。
     -->
  <!-- helloworld缓存 -->
  <cache name="HelloWorldCache"
         maxElementsInMemory="1000"
         eternal="false"
         timeToIdleSeconds="600"
         timeToLiveSeconds="600"
         overflowToDisk="false"
         memoryStoreEvictionPolicy="LRU"/>
</ehcache>

3、如果是Spring boot

@Configuration
public class CacheConfig {

    //EhCacheManager
    @Bean(name = "ehCacheManager")
    public CacheManager cacheManager() {
        EhCacheManagerFactoryBean cacheManagerFactoryBean = new EhCacheManagerFactoryBean();
        cacheManagerFactoryBean.setConfigLocation(new ClassPathResource("ehcache.xml"));
        cacheManagerFactoryBean.setShared(true);
        cacheManagerFactoryBean.afterPropertiesSet();
        return cacheManagerFactoryBean.getObject();
    }
}

设置缓存

/**
 * 设置本地内存
 *
 * @param key
 * @return
 */
@Override
public void setLocalCache(String key, String value, Integer timeout) {
    Cache cache = ehCacheManager.getCache("HelloWorldCache");
    if (timeout == null) {
        timeout = localCacheTimeout;
    }
    if (value != null) {
        Element element = new Element(key, value);
        element.setTimeToLive(timeout);
        cache.put(element);
    }
}

获取本地缓存

public String getLocalCache(String key) {
    Cache cache = ehCacheManager.getCache("HelloWorldCache");
    if (cache == null) {
        return null;
    }
    Element cacheElement = cache.get(key);
    if (cacheElement == null) {
        return null;
    }
    return cacheElement.getObjectValue().toString();
}

4、ehcache 2.x不会主动清楚过期缓存,使用定时任务清楚缓存

/**
 * 定时清除过期本地缓存
 **/
@Slf4j
@Configuration
@EnableScheduling
public class ExpireLocalCacheScheduler {

   @Qualifier("ehCacheManager")
    private CacheManager ehCacheManager

    /**
     * 10分钟清除一次
     */
    @Scheduled(cron = "0 */10 * * * ?")
    private void expiredLocalCache() {
        try {
        Cache cache = ehCacheManager.getCache("HelloWorldCache");
        cache.getKeysWithExpiryCheck();
        cache.evictExpiredElements()
        } catch (Exception e) {
            log.error("evictExpiredLocalCache error!", e);
        }
    }

}

总结ehcache是java内存结构的缓存,内部结构为java ConcurrentHashMap的重写,ehcache3内部结构为ConcurrentHashMap+WeekRefererce

作者认为使用ehcache适合两种业务

1、访问次数多qps特别多,类似web放刷策略

2、需要缓存数据量小

缺点:

如果不使用ehcache集群,在项目集群部署的情况下,敏感数据的更新可能不及时。

1、敏感数据不使用ehcache

2、如果使用建议ehcache的过期时间设置的非常小1-10秒

  • 15
    点赞
  • 78
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 下面是一个示例 Ehcache 3 配置类的代码: ```java import org.ehcache.config.builders.CacheConfigurationBuilder; import org.ehcache.config.builders.CacheManagerBuilder; import org.ehcache.config.builders.ResourcePoolsBuilder; import org.ehcache.config.units.MemoryUnit; import org.ehcache.impl.config.persistence.DefaultPersistenceConfiguration; import org.ehcache.spi.service.ServiceConfiguration; import java.net.URL; import java.util.ArrayList; import java.util.List; public class Ehcache3Config { private CacheManagerBuilder<CacheManager> cacheManagerBuilder; private CacheConfigurationBuilder<String, String> cacheConfigurationBuilder; private ResourcePoolsBuilder resourcePoolsBuilder; private String cacheName; public Ehcache3Config(String cacheName) { this.cacheName = cacheName; this.cacheManagerBuilder = CacheManagerBuilder.newCacheManagerBuilder(); this.cacheConfigurationBuilder = CacheConfigurationBuilder.newCacheConfigurationBuilder(String.class, String.class, resourcePoolsBuilder); this.resourcePoolsBuilder = ResourcePoolsBuilder.newResourcePoolsBuilder().heap(10, MemoryUnit.MB); } public CacheManagerBuilder<CacheManager> getCacheManagerBuilder() { return cacheManagerBuilder; } public CacheConfigurationBuilder<String, String> getCacheConfigurationBuilder() { return cacheConfigurationBuilder; } public ResourcePoolsBuilder getResourcePoolsBuilder() { return resourcePoolsBuilder; } public String getCacheName() { return cacheName; } public void setCacheManagerBuilder(CacheManagerBuilder<CacheManager> cacheManagerBuilder) { this.cacheManagerBuilder = cacheManagerBuilder; } public void setCacheConfigurationBuilder(CacheConfigurationBuilder<String, String> cacheConfigurationBuilder) { this.cacheConfigurationBuilder = cacheConfigurationBuilder; } public void setResourcePoolsBuilder(ResourcePoolsBuilder resourcePoolsBuilder) { this.resourcePoolsBuilder = resourcePoolsBuilder; } public void setCacheName(String cacheName) { this.cacheName = cacheName; } public void setDiskStorePath(String diskStorePath) { URL url = getClass().getResource(diskStorePath); DefaultPersistenceConfiguration persistenceConfiguration = new DefaultPersistenceConfiguration(url); List<ServiceConfiguration<?>> serviceConfigurations = new ArrayList<>(); serviceConfigurations.add(persistenceConfiguration); cacheManagerBuilder.using(serviceConfigurations); } } ``` 上述代码中,配置类 `Ehcache3Config` 包含了用于构建 `CacheManager` 和 `Cache` 的必要参数,例如: - `cacheManagerBuilder`:用于构建 `CacheManager` 的构建器。 - ` ### 回答2: Ehcache3 是一个用于 Java 应用程序缓存的开源框架,它提供了快速、可靠的缓存解决方案。下面是一个简单的 Ehcache3 配置类的示例: ```java import org.ehcache.Cache; import org.ehcache.CacheManager; import org.ehcache.config.CacheConfiguration; import org.ehcache.config.Configuration; import org.ehcache.config.builders.CacheConfigurationBuilder; import org.ehcache.config.builders.CacheManagerBuilder; import org.ehcache.config.builders.ConfigurationBuilder; import org.ehcache.config.units.EntryUnit; import org.ehcache.config.units.MemoryUnit; public class EhcacheConfig { private static final String CACHE_NAME = "myCache"; private static final long CACHE_SIZE_MB = 10; private static final long ELEMENTS_IN_CACHE = 1000; public static void main(String[] args) { Configuration configuration = ConfigurationBuilder.newConfigurationBuilder().build(); CacheConfiguration<String, Integer> cacheConfiguration = CacheConfigurationBuilder .newCacheConfigurationBuilder(String.class, Integer.class, ResourcePoolsBuilder.newResourcePoolsBuilder() .heap(CACHE_SIZE_MB, MemoryUnit.MB) .build()) .withSizeOfMaxObjectGraph(100) .withSizeOfMaxObjectSize(10, MemoryUnit.KB) .withExpiry(ExpiryPolicyBuilder.timeToIdleExpiration(Duration.ofMinutes(10))) .build(); CacheManager cacheManager = CacheManagerBuilder.newCacheManagerBuilder() .withCache(CACHE_NAME, cacheConfiguration) .build(true); Cache<String, Integer> cache = cacheManager.getCache(CACHE_NAME, String.class, Integer.class); // 向缓存中添加数据 cache.put("key1", 1); cache.put("key2", 2); // 从缓存中获取数据 Integer value1 = cache.get("key1"); Integer value2 = cache.get("key2"); System.out.println("Value1: " + value1); System.out.println("Value2: " + value2); // 关闭缓存管理器 cacheManager.close(); } } ``` 这个配置类实例化了一个 Ehcache3 的缓存管理器(CacheManager),并创建了一个名为 "myCache" 的缓存。我们使用 `withCache` 方法将缓存配置(CacheConfiguration)与缓存管理器关联起来。然后,我们可以使用 `getCache` 方法获取指定名称的缓存实例,以便向缓存中添加或获取数据。 在示例中,我们设置了缓存的最大大小为 10 MB,最大元素数量为 1000。我们还指定了缓存对象计算大小的相关配置,同时为缓存设置了过期策略。 通过这个简单的 Ehcache3 配置类,我们可以轻松地配置和使用缓存来提高 Java 应用程序的性能和效率。 ### 回答3: Ehcache3是一个用于在Java应用程序中进行内存缓存管理的开源框架。以下是一个简单的Ehcache3配置类的示例: ```java import org.ehcache.Cache; import org.ehcache.CacheManager; import org.ehcache.config.CacheConfiguration; import org.ehcache.config.Configuration; import org.ehcache.config.builders.CacheConfigurationBuilder; import org.ehcache.config.builders.CacheManagerBuilder; import org.ehcache.config.builders.ConfigurationBuilder; import org.ehcache.config.units.EntryUnit; import org.ehcache.config.units.MemoryUnit; public class EhcacheConfig { private static CacheManager cacheManager; private static Cache<String, String> cache; public static void main(String[] args) { configureCacheManager(); configureCache(); // 使用缓存 cache.put("key", "value"); String value = cache.get("key"); System.out.println(value); // 关闭缓存管理器 cacheManager.close(); } private static void configureCacheManager() { Configuration configuration = ConfigurationBuilder.newConfigurationBuilder().build(); cacheManager = CacheManagerBuilder.newCacheManager(configuration); cacheManager.init(); } private static void configureCache() { CacheConfiguration<String, String> cacheConfiguration = CacheConfigurationBuilder.newCacheConfigurationBuilder(String.class, String.class, ResourcePoolsBuilder.newResourcePoolsBuilder() .heap(100, EntryUnit.ENTRIES) .offheap(1, MemoryUnit.MB) .build()) .build(); cache = cacheManager.createCache("myCache", cacheConfiguration); } } ``` 以上代码中,我们首先创建了一个`CacheManager`对象和一个`Cache`对象,并在`configureCacheManager`方法中通过`ConfigurationBuilder`来构建缓存管理器的配置,再通过`CacheManagerBuilder`来构建缓存管理器。 然后,在`configureCache`方法中,我们使用`CacheConfigurationBuilder`来构建缓存的配置,并指定了缓存的键和值的类型(这里都是`String`类型),以及使用堆内存和堆外内存进行缓存。 最后,在`main`方法中,我们可以使用缓存对象进行常见的缓存操作,比如`put`和`get`方法来存储和读取缓存数据。最后,我们在程序结束时关闭缓存管理器。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值