在测试中,推荐使用我们自己重写的RedisTemplate
在JAVA中,一个对象的信息一般并非连续的,在存储的时候我们会需要提炼为一个连续的数据串(通常是byte array数组或者字符串),这个也正是序列化的字面意思。这样才能将你的对象信息存储起来,或者用于传输。
任何存储都需要序列化。只不过常规你在用DB一类存储的时候,这个事情DB帮你在内部搞定了(直接把SQL带有类型的数据转换成内部序列化的格式,存储;读取时再解析出来)。
而Redis并不会帮你做这个事情。当你用Redis的key和value时,value对于redis来讲就是个byte array。你要自己负责把你的数据结构转换成byte array,等读取时再读出来。
一个特例是字符串,因为字符串自己几乎就已经是byte array了,所以不需要自己处理。
因此当你要用redis存一个东西,你可能会遇到
回到Spring这边。Spring的redisTemplate默认会使用java serialization做序列化。你也可以用StringRedisTemplate,那么你set的所有数据都会被toString一下再存到redis里。但这个toString不一定能反解析的回来……
总之简单一句话,你要形成一个序列化的约定,确保存进去的东西能解析回来不出错。也许你可以和你的team商量一个规范。
不建议试用默认java的对象序列化,推荐自己序列化为json后存储,否则各种兼容问题
因为我们在自定义RedisTemplate时,泛型定义为<String, Object>。
key都是String,就可以使用简单的StringRedisSerializer来做简单的序列化,反序列化即可;
而value是Object,略微复杂,仅仅靠StringRedisSerializer(--类似toString()的逻辑,序列化后不一定能反序列化成功...)是不行的。
redis储存对象,这个类需要实现序列化接口: class User implements Serializable. 或者,对象保存之前就序列化为json字符串之类的。
用来封装RedisTemplate原始的,但是用起来复杂的API。封装层略微简单些的函数。
(截图未包含所有的封装API,因为太多了)
作者:大宽宽
链接:https://www.zhihu.com/question/277363840/answer/392945240
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
Redis - Redis整合SpringBoot + 自定义RedisTemplate
原文:https://www.cnblogs.com/frankcui/p/14660466.html