Ehcache和Redis封装接口(支持缓存切换)

一、EhCache和Redis简介
EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点。

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库

二、Ehcache和Redis的区别
1、操作简易程度:Ehcache操作简单易使用;Redis支持多种数据类型,操作较复杂。
2、存取速度:两者存取速度都较快。
3、应用场景:Ehcache更适合用于中小型应用;Redis更适合用于大数据缓存、数据恢复等场景。
4、持久化:Ehcache数据持久化较弱;Redis支持数据持久化,可以将更新的数据写入磁盘或追加记录文件。
5、分布式:Ehcache不适合大型分布式集群部署;Redis支持分布式。

三、封装使用
1、第一步,引入需要的依赖包

<!-- redis依赖-->
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

<!-- ehcache依赖-->
<dependency>
	<groupId>net.sf.ehcache</groupId>
	<artifactId>ehcache</artifactId>
</dependency>

2、第二步,定义缓存接口

public interface CacheService<K, V> {

    void put(K key, V value, Duration ttl);

    V get(K key);

    void delete(K key);

    V getAndDelete(K key);
}

3、第三步,编写Ehcache实现类,实现CacheService缓存接口

public class EhcacheCacheServiceImpl<K, V> implements CacheService<K, V> {

    private CacheManager cacheManager;

    private static final String CACHE_NAME = "myCache";

    @Override 
    public void put(K key, V value, Duration ttl) {
        Element element = new Element(key, value);
        element.setTimeToLive((int) ttl.getSeconds());
        getCache().put(element);
    }

    @Override 
    public V get(K key) {
        Element element = getCache().get(key);
        return (element != null) ? (V) element.getObjectValue() : null;
    }

    @Override 
    public void delete(K key) {
        getCache().remove(key);
    }

    @Override
    public V getAndDelete(K key) {
        Element element = getCache().removeAndReturnElement(key);
        return (element != null) ? (V) element.getObjectValue() : null;
    }
}

4、第四步,编写Redis实现类,实现CacheService缓存接口

public class RedisCacheServiceImpl <K, V> implements CacheService<K, V> {

    private RedisTemplate<K, V> redisTemplate;

    @Override
    public void put(K key, V value, Duration ttl) {
        redisTemplate.opsForValue().set(key, value, ttl);
    }

    @Override
    public V get(K key) {
        return redisTemplate.opsForValue().get(key);
    }

    @Override
    public void delete(K key) {
        redisTemplate.delete(key);
    }

    @Override
    public V getAndDelete(K key) {
        return redisTemplate.opsForValue().getAndDelete(key);
    }
}

5、最后编写配置类,通过配置控制使用哪一种缓存,支持缓存的切换

@Configuration
@EnableCaching
public class CacheConfig {

    @NacosValue(value = "${cache.type:}", autoRefreshed = true)
    private String cacheType;

    @Autowired(required = false)
    private RedisConnectionFactory redisConnectionFactory;

    @Autowired(required = false)
    private RedisTemplate<String,String> redisTemplate;

    @Bean
    public CacheManager crateCacheManager() {
        if (cacheType.equals("redis")){
            RedisCacheConfiguration cacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
                    .entryTtl(Duration.ofMinutes(10));
            return RedisCacheManager.builder(RedisCacheWriter.lockingRedisCacheWriter(redisConnectionFactory))
                    .cacheDefaults(cacheConfiguration).build();
        } else {
            return  new EhCacheCacheManager(ehCacheFactory().getObject());
        }
    }
    @Bean
    public CacheService<String,String> crateCacheService(net.sf.ehcache.CacheManager cacheManager) {
        if (cacheType.equals("redis")){
            RedisCacheServiceImpl<String,String> redisCacheServiceImpl = new RedisCacheServiceImpl<>();
            redisCacheServiceImpl.setRedisTemplate(redisTemplate);
            return redisCacheServiceImpl;
        } else {
            EhcacheCacheServiceImpl<String,String> cacheCacheServiceImpl = new EhcacheCacheServiceImpl<>();
            cacheCacheServiceImpl.setCacheManager(cacheManager);
            return cacheCacheServiceImpl;
        }
    }

    @Bean
    public EhCacheManagerFactoryBean ehCacheFactory() {
        EhCacheManagerFactoryBean ehCacheFactoryBean = new EhCacheManagerFactoryBean();
        ehCacheFactoryBean.setConfigLocation(new ClassPathResource("ehcache.xml"));
        ehCacheFactoryBean.setShared(true);
        return ehCacheFactoryBean;
    }

}
  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值