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