Redis 请求缓存简单了解下

希望能对正在学习java的朋友提供一点帮助

package com.xxxx.demo;

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonTypeInfo;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
import org.springframework.cache.annotation.CachingConfigurerSupport;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.*;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.StringRedisSerializer;

import java.time.Duration;

@Configuration
public class RedisConfig extends CachingConfigurerSupport {
    /*
    RedisConnectionFactory  工厂有两种方式 1 jedis  2,lettuce
    redis本身默认基于jdk的序列化 压缩大小是比json 小大约五倍左右  需要从写序列化
    */
    @Bean
    public RedisTemplate<String,String> getRedisTemplate(RedisConnectionFactory redisConnectionFactory){
        RedisTemplate<String,String> template =new RedisTemplate<String, String>();

        //Object.class在反序列化的时候不设置ObjectMapper 会生成linkedHashMap类型 返回纯json数据
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper objectMapper = new ObjectMapper();
        /*
         AVA_LANG_OBJECT: 当对象属性类型为Object时生效;
         OBJECT_AND_NON_CONCRETE: 当对象属性类型为Object或者非具体类型(抽象类和接口)时生效;
         NON_CONCRETE_AND+_ARRAYS: 同上, 另外所有的数组元素的类型都是非具体类型或者对象类型;
         NON_FINAL: 对所有非final类型或者非final类型元素的数组。包含以上
        */

        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        objectMapper.activateDefaultTyping( LaissezFaireSubTypeValidator.instance ,ObjectMapper.DefaultTyping.NON_FINAL,
                JsonTypeInfo.As.PROPERTY);
        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
        /*
        1、JsonTypeInfo.As.PROPERTY:作为数据的兄弟属性
        2、JsonTypeInfo.As.EXISTING_PROPERTY:作为POJO中已经存在的属性

        3、JsonTypeInfo.As.EXTERNAL_PROPERTY:作为扩展属性

        4、JsonTypeInfo.As.WRAPPER_OBJECT:作为一个包装的对象

        5、JsonTypeInfo.As.WRAPPER_ARRAY:作为一个包装的数
        */
        //为string类型的key设置序列化器
        template.setKeySerializer(new StringRedisSerializer());
        //为string类型的values设置序列化器
        template.setValueSerializer(jackson2JsonRedisSerializer);
        //为hash类型的key设置序列化器
        template.setHashKeySerializer(new StringRedisSerializer());
        //为hash类型的values设置序列化器
        template.setHashKeySerializer(jackson2JsonRedisSerializer);
        template.setConnectionFactory(redisConnectionFactory);  //必须添加 redis工厂
        return template;

    }
    //缓存配置管理器
    @Bean
    public RedisCacheManager cacheManager (RedisConnectionFactory redisConnectionFactory) {
        RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofHours(7))   // 设置缓存过期时间
            //  .disableCachingNullValues()     // 禁用缓存空值,不缓存null校验
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
                //  注意GenericJackson2JsonRedisSerializer反序列化时没有类型
                // 正常应使用自定义的序列化器
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer()));
                 //cacheDefaults必须第一个配置 否则运行默认配置
        return RedisCacheManager.builder(redisConnectionFactory).cacheDefaults(redisCacheConfiguration).build();     // 设置默认的cache组件

    }
}

yml中redis简单配置

spring:
  redis:
    timeout: 10000  #连接超时时间
    host: #########  #redis的服务地址
    port: 6379      #redis端口号
    password: root  #redis服务器密码
    database: 0     #选择哪个库 默认为0库
    lettuce:
      pool:
        max-active: 1024  #最大连接数 默认为8
        max-idle: 200     #最大空闲连接 默认为8
        max-wait: 10000  #最大连接阻塞等待时间 单位毫秒 默认为-1 不限制
        min-idle: 5      #最小空闲默认为0