一、创建SpringBoot项目
创建时勾上 Redis。
注意:在 SpringBoot 2.x 之后,原来使用的 jedis 被替换为了 lettuce。
jedis 和 lettuce 有什么区别呢?
- jedis:采用直连,多个线程操作时不安全,如果想要避免不安全,使用 jedis pool 连接池!BIO
- lettuce:采用 netty,实例可以在多个线程中进行共享,不存在线程不安全的情况。可以减少线程数据了,更像 NIO 模式。
Redis 可以配置的字段
到 RedisAutoConfiguration
中找到 RedisProperties
。
进入 RedisProperties
查看。
注:从此处也可以看到,连接 Redis 由 Jedis 和 lettuce 两种方式。
二、测试
1. 配置yml
2. 原生API测试(RedisTemplate)
拿到 RedisTemplate,可以得到操作不同数据结构的 Operation(比如 ValueOperations, HashOperations),然后调用方法即可。(ValueOperations 对应 String)。
获取连接也可以操作。
写入 k1 : zhangsan
@SpringBootTest
class Redis02SpringbootApplicationTests {
@Autowired
private RedisTemplate redisTemplate;
@Test
void contextLoads() {
redisTemplate.opsForValue().set("k1", "zhangsan");
System.out.println(redisTemplate.opsForValue().get("k1"));
}
}q
3. 自定义RedisTemplate
由于原生的RedisTemplate是默认使用JDK动态代理,所以直接传递未实现 Serializable 接口的对象会报无法序列化异常。
实现 Serilizable 接口后再进行测试,成功。
查看服务器上 Redis 发现问题: 当我们使用原生api时,可以看到插入的key并不是`"user"`,而是 `"\xac\xed\x00\x05t\x00\x04user"`,并且调用使用 `key *` 获得的 key 的集合为空。
为了让key,value按照我们希望的形式存入 Redis,就需要我们自己来实现一个 RedisTemplate,实现如下:
public class RedisConfig {
// 编写自己的 redisTemplate
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<String, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);
ObjectMapper om = new ObjectMapper();
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(om);
// String 的序列化
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
// Key采用String的序列化方式
template.setKeySerializer(stringRedisSerializer);
// hash的key也采用String的序列化方式
template.setHashKeySerializer(stringRedisSerializer);
// value 采用jackon
template.setValueSerializer(jackson2JsonRedisSerializer);
// hash 的 value 采用jackon
template.setHashValueSerializer(jackson2JsonRedisSerializer);
template.afterPropertiesSet();
return template;
}
}
从运行结果看出,插入的key,value正常。