

@toc
<font color='red'>答案:</font>严谨说并不是数据隔离,而应该说成是彼此存入redis的数据存在,但是访问不到;而数据隔离通常指的是数据存在同一个库下,但是自己只能查看并访问自己的数据,而redis中数据都能看到且只是使用不同RedisTemplate和StringRedisTemplate对象彼此访问不到而已。
<font color='red'>答案:</font>所谓的彼此访问不到数据,前提是自己不重新对RedisTemplate进行序列化设置,<font color='red'>大白话讲就是直接使用默认的,这样才能实现彼此数据隔离访问不到</font>,而实现了序列化后RedisTemplate和StringRedisTemplate对字符串类型数据就都能获取了。
而我的能访问到就是我对RedisTemplate进行了序列化设置,比如如下代码,<font color='red'>注意这一行: template.setKeySerializer(RedisSerializer.string());</font>这样设置后就<font color='red'>会导致RedisTemplate和StringRedisTemplate针对string类型的属性值使用了相同的序列化方式</font>,这样就能彼此访问到数据了;反之不设置这一行,就会彼此反问不到数据。
package com.example.demo.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
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.RedisSerializer;
@Configuration
public class RedisConfig {
@Bean(name = "redisTemplate")
public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, String> template = new RedisTemplate<>();
template.setConnectionFactory(factory);
//key的序列化采用String类型的
template.setKeySerializer(RedisSerializer.string());
//value的序列化采用jackson类型
template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
//hash的key的序列化也采用String类型
template.setHashKeySerializer(RedisSerializer.string());
//value的序列化采用jackson类型
template.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
template.afterPropertiesSet();
return template;
}
}RedisTemplate的序列化


StringRedisTemplate的序列化

@Test
public void redisTemplateAndStringRedisTemplate1() {
redisTemplate.opsForValue().set("redisTemplateListKey","abc");
stringRedisTemplate.opsForValue().set("stringRedisTemplateListKey","def");
}结果如下:
可以发现stringRedisTemplate存入的还是字符串样式,能直接看出属性值为def,<font color='red'>然而RedisTemplate存入的key值前面居然多加了一串16进制的字符串值,同时存入redis的结果也是转换为字节数组bytes之后的看不懂的值</font>。
stringRedisTemplate

RedisTemplate

<font color='red'>答案:</font>区别在于RedisTemplate存入redis的字符串有双引号,而StringRedisTemplate存入redis的字符串居然没有双引号。
代码如下:
@Test
public void redisTemplateAndStringRedisTemplate1() {
redisTemplate.opsForValue().set("redisTemplateListKey","abc");
stringRedisTemplate.opsForValue().set("stringRedisTemplateListKey","def");
}结果展示如下: RedisTemplate

StringRedisTemplate

源码分析:
<font color='red'>先看 StringRedisTemplate:</font>
StringRedisTemplate 是继承 RedisTemplate的,一般来说子类继承父类,应该能实现更多的功能,但是此处我们发现 StringRedisTemplate 继承的是 RedisTemplate的泛型类,指定了String-String的泛型!故功能只专注于String类型!

这下就一目了然了!
<font color='red'>再看 RedisTemplate:</font>

<font color='red'>答案:</font>RedisTemplate 可以接收任意的 Object 作为值写入 Redis,只不过写入前会把 Object 序列化为字节形式,默认采用 JDK 序列化。但是这种方式有两个缺点:
<font color='red'>答案:4种:字符串序列化、json序列化、jdk序列化
JdkSerializationRedisSerializer、StringRedisSerializer、GenericJackson2JsonRedisSerializer、GenericFastJsonRedisSerializer。</font>
其中:StringRedisSerializer =》 字符串序列化
JdkSerializationRedisSerializer =》 jdk序列化
GenericJackson2JsonRedisSerializer和GenericFastJsonRedisSerializer =》 json序列化
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。