springboot 2+redis 2 的cacheable用法与配置

用法
类上(最好是放在服务层)加
@CacheConfig(cacheNames = “default”,keyGenerator = “keyGenerator”)
方法上加
@Cacheable(keyGenerator = “keyGenerator”,cacheNames=“default”)

引入包

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-data-redis</artifactId>
		</dependency>
		<!--连接redis-->
		<dependency>
			<groupId>org.apache.commons</groupId>
			<artifactId>commons-pool2</artifactId>
		</dependency>

配置文件,根据时间配置三个缓存名,并且把它们的序列化方式,设定序列化

package ca.citylinkiot.battery_charging.config;

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.cache.interceptor.KeyGenerator;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.cache.RedisCacheWriter;
import org.springframework.data.redis.connection.*;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.*;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.RedisSerializer;

import javax.annotation.Resource;
import java.lang.reflect.Method;
import java.time.Duration;
import java.util.*;

/**
 * Created by admin on 2019/9/24.
 */
@Configuration
@EnableCaching
public class CacheConfig {
//    @Bean
//    RedisTemplate redisTemplate(){
//        return
//    }
//    @Resource
//    RedisTemplate redisTemplate;
//    @Resource
//    StringRedisTemplate stringRedisTemplate;
    /*@Bean
    @ConfigurationProperties(prefix = "spring.redis")
    RedisConnectionFactory redisConnectionFactory(){
//        return new JedisConnectionFactory();
        LettuceConnectionFactory lettuceConnectionFactory=new LettuceConnectionFactory();
        lettuceConnectionFactory.
    }*/
//    @Resource
//    LettuceConnectionFactory lettuceConnectionFactory;
    @Bean
    @ConfigurationProperties(prefix = "spring.redis")
    RedisConnectionFactory lettuceConnectionFactory(){//LettuceConnectionFactory是RedisConnectionFactory的实现
        return new LettuceConnectionFactory();
    }

    @Bean
    RedisCacheManager redisCacheManager(RedisConnectionFactory redisConnectionFactory) {
        RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofHours(1)) // 设置缓存有效期一小时
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(RedisSerializer.json()));

//        RedisCacheManager redisCacheManager = RedisCacheManager
//                .builder(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory))
//                .cacheDefaults(redisCacheConfiguration).build();
        Map<String, RedisCacheConfiguration> initialCacheConfigurations=new HashMap<>();
        initialCacheConfigurations.put("sixHoursCache",RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofHours(6))
//                     这一行代码会导致空置针,但是上面设置这一项,却没有控制真错误
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(RedisSerializer.json())));;
        initialCacheConfigurations.put("fiveMinutesCache",RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofMinutes(5))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(RedisSerializer.json())));;
        RedisCacheManager redisCacheManager=new RedisCacheManager(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory),
                redisCacheConfiguration,
                initialCacheConfigurations);
        return redisCacheManager;
    }

    @Bean
    public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
                StringRedisTemplate template = new StringRedisTemplate(factory);
                Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
                ObjectMapper om = new ObjectMapper();
                om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
                om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
                jackson2JsonRedisSerializer.setObjectMapper(om);
                template.setValueSerializer(jackson2JsonRedisSerializer);
                template.setHashValueSerializer(jackson2JsonRedisSerializer);
                template.afterPropertiesSet();
                return template;
            }

    @Bean
    public KeyGenerator keyGenerator() {
        return new KeyGenerator() {
            @Override
            public Object generate(Object target, Method method, Object... params) {
                StringBuilder sb = new StringBuilder();
                String className = target.getClass().getName();//.replace("com.duia.home.service.impl.","").replace("ServiceImpl","");
                sb.append(className + ".");
                sb.append(method.getName() + ".");
                                /*for (Object obj : params) {
//                                        if (obj instanceof Date){
//                                                sb.append( DateUtils.format((Date) obj,"yyyy-MM-dd"));
//                                            }else {
//                                                sb.append (obj.toString());
//                                            }

                                    }*/
//                                sb.append(Collections.)
                String paraStr = Arrays.asList(params).toString();
                sb.append(paraStr);
                return sb.toString();
            }
        };
    }
}

yml 配置

spring:
 redis:
#    nodes: localhost # 192.168.1.81:7000,192.168.1.81:7001,192.168.1.81:7002
    host: localhost
#    url
    password: 667
    timeout: 20000
#    pool:
#      max-idle: 100
#      min-idle: 1
#      max-active: 1000
#      max-wait: -1
    lettuce: # 这里标明使用lettuce配置
          pool:
            max-active: 8   #连接池最大连接数(使用负值表示没有限制)
            max-wait: -1ms  #连接池最大阻塞等待时间(使用负值表示没有限制)
            max-idle: 5     #连接池中的最大空闲连接
            min-idle: 0     #连接池中的最小空闲连接
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值