设为首页 收藏本站
查看: 722|回复: 0

[经验分享] Redis序列化存储Java集合List等自定义类型

[复制链接]
发表于 2018-11-2 14:11:54 | 显示全部楼层 |阅读模式
  在“Redis学习总结和相关资料”http://blog.csdn.net/fansunion/article/details/49278209
  这篇文章中,对Redis做了总体的介绍,演示了Jedis和SpringDataRedis访问Redis的相关例子。
  对于基本的CRUD差不多够了。
  随着项目中使用场景的增多,出现了存储Java集合List的情况。
  这个时候,一般的代码很可能会报错,比如“无法序列化”,“序列化失败”之类的~
  经过几个小时的实践探索,参考了在秒针工作的代码以及最近的代码,有2种可行方法。
  需要说明的是,项目中用的是SpringDataRedis,但是Jedis代码的思路也是一样的。
  项目中的Redis配置
  [html] view plain copy print?

  •   
  •   
  •   
  •   
  •   
  •   
  •   
  •   
  •   
  •   
  
  
  
  
  
  
  
  
  
  直接存储java.util.List会提示“无法序列化”,“JdkSerializationRedisSerializer序列化失败”类似的错误,
  简单的把java.util.List的元素实现Serialiable接口,是不行的。
  也考虑了下,是不是和List元素的serialVersionUID有关系,最初用的是默认值1,改成系统生成的,也还是不行.
  private static final long serialVersionUID = -2162380932844568332L;
  有想要Java视频资料的请加731661047
  方法1:把List转换成JSON,存储到Redis,取出来的时候,再把JSON转换成List。
  这种方法也很不错,但是,当时咋就没有想到呢。
  序列化存储
  [java] view plain copy print?

  •   List list = new ArrayList();
  •   String json=JSONObject.toJSONString(list);
  •   logger.info("save json="+json);
  •   defaultCache.add(key, json, CATCHE_TIME);
List list = new ArrayList();  
  String json=JSONObject.toJSONString(list);
  
  logger.info("save json="+json);
  
  defaultCache.add(key, json, CATCHE_TIME);
  反序列化
  [java] view plain copy print?

  •   Object jsonInRedis = defaultCache.getValue(key);
  •   List list = null;
  •   Object listInRedis = null;
  •   if(jsonInRedis != null){
  •   logger.info("get json="+jsonInRedis);
  •   listInRedis= JSONObject.parseArray(jsonInRedis.toString(), MatchContent.class);
  •   }
  •   if (listInRedis instanceof List) {
  •   list = (List) listInRedis;
  •   logger.debug("Find fund4Project in redis~ size=" + list.size());
  •   }
  Object jsonInRedis = defaultCache.getValue(key);  List list = null;
  Object listInRedis = null;
  if(jsonInRedis != null){
  logger.info("get json="+jsonInRedis);
  listInRedis= JSONObject.parseArray(jsonInRedis.toString(), MatchContent.class);
  }
  if (listInRedis instanceof List) {
  list = (List) listInRedis;
  logger.debug("Find fund4Project in redis~ size=" + list.size());
  }
  需要特别说明的是, JSONObject.parseArray可以把json格式的字符串,转换成Java的List。
  这个方法之前用的少,一直不熟悉,第2个参数是List元素的class。
  自己写的1个Demo。
  [java] view plain copy print?

  •   public static void main(String[] args) {
  •   List list = new ArrayList();
  •   list.add(new User());
  •   String json=JSONObject.toJSONString(list);
  •   System.out.println(json);
  •   List newList=JSONObject.parseArray(json, User.class);
  •   System.out.println(newList.size());

  •   }
public static void main(String[] args) {  List list = new ArrayList();
  list.add(new User());
  String json=JSONObject.toJSONString(list);
  System.out.println(json);
  List newList=JSONObject.parseArray(json, User.class);
  System.out.println(newList.size());
  }
  方法2:把List转换成二进制数组byte[],存储到Redis,取出来的时候,再把byte[]转成List。
  序列化list->byte[]
  [java] view plain copy print?

  •   import hprose.io.HproseFormatter;
  •   java.io.ByteArrayOutputStream baos=HproseFormatter.serialize(list);
  •   byte[] bytes=baos.toByteArray();
import hprose.io.HproseFormatter;  
java.io.ByteArrayOutputStream baos=HproseFormatter.serialize(list);
  byte[] bytes=baos.toByteArray();
  二进制反序列化byte[]->list
  listInRedis = HproseFormatter.unserialize((byte[] )bytesInRedis);
  项目中用的是源代码,从秒针代码中copy出来的库。
  上述2种方法,使用JSON序列化存储,感觉更简单一些。
  但是据说HproseFormatter这个库,很牛逼,按照官网的说法。
  Hprose(High Performance Remote Object Service Engine)
  是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。
  你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。
  网上找到了hprose的资料,不出意外的话,可以用下面这个的。
  hprose/hprose-java
  https://github.com/hprose/hprose-java/tree/master/src
  Map等其它类型的存储,和List类似~
  把Redis序列化这个问题解决了,感觉方法很简单。
  还是那句经典的话“难题不会,会题不难”。
  等把问题解决了,再难的问题,已经变得简单了。没解决的时候,急死你。
  伙计,加油~
  原文链接:https://blog.csdn.net/FansUnion/article/details/49890901



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-629932-1-1.html 上篇帖子: GO(9[TCP/Redis/原子操作]) 下篇帖子: ubantu 安装 redis-wangni858的博客
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表