springboot~redis正确的使用
redis实现了对数据的缓存,在项目里一些字典数据,会话数据,临时性数据都会向redis来存储,而在springboot里对redis也有支持,一般来说多个线程共同使用一个redis实现是有线程安全的风险的,而每个实现一个线程又太浪费资源,无法控制线程数量是非常危险的,所以就出现了一些redis线程池组件,下面说一下两个主要的组件。
- jedis 线程池主要是每个实例有自己的线程,线程可以从它建立的池子里获取
- lettuce lettuce是 apache推出的线程池工具,它的redis实例是可以被多个线程共享访问的,提高了资源使用率
redis序列化配置
一般来说, redis-key采用字符串序列化; redis-value采用json序列化, json的体积小,可读性高,不需要实现serializer接口。
/**
* 对redis的配置.
*/
@Configuration
public class RedisConfig {
@Autowired
private RedisConnectionFactory redisConnectionFactory;
/**
* redis重写RedisTemplate.
*/
@Bean
public RedisTemplate redisTemplate() {
RedisTemplate redisTemplate = new RedisTemplate();
RedisSerializer<String> stringSerializer = new StringRedisSerializer();
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper om = new ObjectMapper();
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
//序列化时允许非常量字段均输出类型,即redis序列化后带有类型
om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(om);
// redis key的序列化
redisTemplate.setKeySerializer(stringSerializer);
redisTemplate.setHashKeySerializer(stringSerializer);
// redis value的序列化
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setConnectionFactory(redisConnectionFactory);
return redisTemplate;
}
}
上面代码中,om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL)
产生的json串是带有类型的,这样再反序列化时可以直接通过类型去推断。
[
"com.lind.basic.entity.Token",
{
"credentials": "ok",
"region": "hello",
"bucket": null
}
]
看一下添加和读取的代码
@GetMapping("set")
public String set() throws JsonProcessingException {
Token token = Token.builder()
.credentials("ok")
.region("hello")
.build();
redisTemplate.opsForValue().set("test:user", token);//redisTemplate帮我们序列化
redisTemplate.opsForHash().put("author", "zzl", token);
return "OK";
}
@GetMapping("get")
public Token get() throws IOException {
return (Token) redisTemplate.opsForValue().get("test:user");
}
注意:对于实体类Token它应该有一个无参构造方法,这是反序列化时需要的。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2019-05-28 spring单元测试下模拟rabbitmq
2015-05-28 MongoDB学习笔记~以匿名对象做为查询参数,方便查询子对象
2015-05-28 Moebius实现Sqlserver集群~介绍篇
2015-05-28 知方可补不足~SQL数据库用户的克隆,SQL集群的用户同步问题
2012-05-28 架构,改善程序复用性的设计~第三讲 实现一种功能的代码只能出现在一处
2012-05-28 架构,改善程序复用性的设计~(第一和第二讲目录)