`
jimgreat
  • 浏览: 131447 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

spring-data-redis 的序列化问题

阅读更多

前几天有人在我的博文中留言,询问spring-data-redis的问题,如下,黑体为我的回答

 

 

我用spring-data-redis 成功的set了 而且也能成功get出来对应的数据~

但是用redis-cli去服务器直接get数据是提示(nil) 这是什么原因啊?

 

正常是get一个不存在的key才会这样的

 

但是我用的是同一个key啊···通过spring-data-redis就可以成功get出来~~

如果我直接用jedis存的话就没有这样的问题·· 大侠解惑啊····

 


我在项目中都是直接用jedis

突然想起spring-data-redis 对 key 和 value 都进行了序列化 变成byte[] 再调用对应的redis java client进行存储的。  那应该就是通过spring-data-redis进入redis的key变了

 

 

今天就这个问题详细分析一下

 

可能我们正常使用redis时 key 和 value 一般都是 string 类型的

但client 和 server 间的协议要求的是 byte   可参看我的另一篇博文 http://jimgreat.iteye.com/blog/1586671

Jedis 提供了 string 和 byte[] 类型的函数接口

 

 

spring-data-redis  中的核心操作类是  RedisTemplate<K, V>

可以看出 key 和 value 都是泛型的,这就涉及到将类型进行序列化的问题了

所就在 RedisTemplate 中还有几个 RedisSerializer

 

 

	private RedisSerializer<?> defaultSerializer = new JdkSerializationRedisSerializer();

	private RedisSerializer keySerializer = null;
	private RedisSerializer valueSerializer = null;
	private RedisSerializer hashKeySerializer = null;
	private RedisSerializer hashValueSerializer = null;
	private RedisSerializer<String> stringSerializer = new StringRedisSerializer();
 

如果没有特殊的设置,key 和 value 都是使用 defaultSerializer = new JdkSerializationRedisSerializer(); 进行序列化的。

 

对于 key = "AAAA"  value = "cccc" 的情况, server 端运行的情况如下

 

 "SET" "\xac\xed\x00\x05t\x00\x04AAAA" "\xac\xed\x00\x05t\x00\x04cccc"

 "GET" "\xac\xed\x00\x05t\x00\x04AAAA"

 

如果项目中只使用了string的 key 和 value ,显然这样不适合在sever上进行debug

 

通过下面的配置,可以改成使用StringRedisSerializer对 key 和 value 进行序列化

 

 

  <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"
    p:connection-factory-ref="jedisConnectionFactory" >
       <property name="KeySerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"></bean>
        </property>
        <property name="ValueSerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"></bean>
        </property>       
    </bean>

 

这样就能在 server 上找到你原来的 key 了 

 

 "SET" "AAAA" "cccc"

 "GET" "AAAA"

 

对于Hash结构内部的 key 和 value 可以添加如下配置

 

 

        <property name="HashKeySerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"></bean>
        </property>  
        <property name="HashValueSerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"></bean>
        </property> 
分享到:
评论
1 楼 jimmys 2016-06-29  
请问spring-data-redis和jedis那种方式比较好

相关推荐

    spring-data-redis-1.7.10.RELEASE jar包

    Spring-data-redis是spring大家族的一部分,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,...

    spring-data-redis-demo.rar

    Spring-data-redis是spring大家族的一部分,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,...

    spring-data-redis-demo

    Spring-data-redis是spring大家族的一部分,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,...

    springdataredis-demo

    SpringDataRedis客户端 SpringData是Spring中数据操作的模块,包含对各种数据库的集成,其中对Redis的集成模块就叫做SpringDataRedis,官网地址:https://spring.io/projects/spring-data-redis - 提供了对不同...

    redis-object-spring-boot-starter

    项目中使用redis序列化的时候,避免手动序列化对象和返回序列化。 引入项目: &lt;groupId&gt;com.even&lt;/groupId&gt; &lt;artifactId&gt;haixue-spring-boot-starter-redis &lt;version&gt;2.0.2-SNAPSHOT 在springboot 配置文件中配置...

    springboot整合spring-data-redis遇到的坑

    使用springboot整合redis,使用默认的序列化配置,然后使用redis-client去查询时查询不到相应的key.问题出在哪,怎么解决呢?下面小编给大家带来了springboot整合spring-data-redis遇到的坑,需要的的朋友参考下吧

    xun:spring, spring-mvc, struts2, freemarker, hibernate, mybatis, spring-data-jpa, shiro

    -展示柜奥普方面spring-aop 引导程序缓存——弹簧缓存数据库米巴蒂斯蔚来米娜2 nosql redis -- jedis, spring-data-redis 序列化——msgpack,protobuf 测试单位——dbunit、easymock、junit、mockito、powermock ...

    spring mvc后台管理系统

    简单后台管理系统 基于maven管理,整合最新spring mvc 4.3.3.RELEASE版整合了mybatis 3.4.1,涵盖了目前互联网web系统最流行的组件,log4j2日志、freemarker模板、protostuff序列化、fastjson、redis、spring-data-...

    SpringDataRedis Demo

    Spring-data-redis是spring大家族的一部分,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,...

    Java进阶教程数据层全栈方案SpringData高级应用视频教程

    4.SpringData Redis的序列化器 5.SpringData Redis运行原理分析 6.SpringData Redis常见操作 第七章 Repository和Template的选用 第八章 SpringData ElasticSearch 1.SpringData ElasticSearch简介 2.ElasticSearch...

    spring data redis 封装使用

    基于SpringBoot搭建 Redis操作 包括String、Hash、List、Set、ZSet 使用protostuff序列化和反序列化 注释齐全欢迎大家下载使用

    springboot-redis-entire:重点是redis缓存,其他功能都可以添加

    1.序列化可以阅读 y 2.用RedisTemplate操作redis y 3.用注解的方式 4.页面增删改查,分页,简单搜索 5.登录,权限控制 y 6.springsession实现共享session 第一步 加依赖 &lt;!-- ...

    尚硅谷Java视频教程_Spring Boot视频教程(下)整合篇

    SpringBoot高级-缓存-@Caching&@CacheConfig 10、尚硅谷-SpringBoot高级-缓存-搭建redis环境&测试 11、尚硅谷-SpringBoot高级-缓存-RedisTemplate&序列化机制 12、尚硅谷-SpringBoot高级-缓存-自定义CacheManager 13...

    redis demo

    Spring data redis提供的几种对象序列化机制的比较

    128元尚硅谷Java视频教程_Spring Boot视频教程(下)整合篇

    23、尚硅谷-SpringBoot高级-检索-整合SpringDataElasticsearch 24、尚硅谷-SpringBoot高级-任务-异步任务 25、尚硅谷-SpringBoot高级-任务-定时任务 26、尚硅谷-SpringBoot高级-任务-邮件任务 27、尚硅谷-SpringBoot...

    Nginx安装包

    需要注意的是如果要往redis中存入对象,则需要改对象序列化才能存入。我这里为了方便,就用fastjson将对象转为字符串存入了,查看起来也方便点。 另外个人中心页面很简单。 现在已经完成测试前的全部工作了,...

    单点登录源码

    Protobuf & json | 数据序列化 | [https://github.com/google/protobuf](https://github.com/google/protobuf) Jenkins | 持续集成工具 | [https://jenkins.io/index.html](https://jenkins.io/index.html) Maven | ...

    开源bbs源码java-blog:刘飞的博客

    开源 bbs 源码 java 网站 : 后台管理系统: update date : 2018-05-13 ...(7)引入spring-data-redis,修改接口的返回值是JSONObject(原来的ObjectMapper不支持Redis的序列化)(2018-04-12) (8)自定义登录异常

    redis-pop-up-store:使用RedisTimeSeries,RedisGears和Redis数据源(用于Grafana)的弹出式商店演示

    使用RedisTimeSeries,RedisGears和Redis Data Source for Grafana的弹出式商店演示 弹出商店演示正在使用 , , 和来可视化Grafana中的数据管道。这个怎么运作 Node.js脚本向客户和订单流添加随机数据RedisGears...

    阿里云ossjava源码-seezoon-stack:一款基于当前最前沿的前端(Vue3+Vite+Antdv)和后台(Springboot)

    阿里云 oss java源码 简介 Seezoon Stack 以快速开发为目的,在开发速度和代码结构上做出一定取啥,无论如何,你将看到...封装,序列化 RestTemplate 线程池、证书请求及默认属性约定 Spring Boot 异步线程配置 跨域

Global site tag (gtag.js) - Google Analytics