Redis存取序列化与反序列化性能问题详解_Redis

来源:脚本之家  责任编辑:小易  

1. 问题场景

我们在使用Redis的时候经常会将对象序列化存储到Redis中,在取出的时候进行反序列化,如果对象过大在进行序列化和反序列化的时候会有一定性能问题。今天查看了CSRedis源码发现在Set和Get的时候是支持Byte[]类型,那么问题来了如果我们将对象转换成Byte[]类型进行存储是否会比序列化和反序列化操作快了?

2. 问题验证

2.1. 编写一个简单实例进行验证

  List<User> list = new List<User>();
  for (int i = 0; i < 1000; i++)
  {
   User user = new User() { Id = i, Name = "张三", Age = 11 };
   list.Add(user);
  }
  Stopwatch stopwatch = new Stopwatch();
  stopwatch.Start(); // 开始监视代码运行时间

  //使用序列化
  rds.HSet("test2", "test2", list);
  var list1 = rds.HGet<List<User>>("test2", "test2");

  //使用byte方式
  //rds.HSet("test", "test1", ObjectToBytes(list));
  //var list2 = BytesToObject(rds.HGet<byte[]>("test", "test1"));

  stopwatch.Stop(); // 停止监视
  TimeSpan timespan = stopwatch.Elapsed; // 获取当前实例测量得出的总时间
  double hours = timespan.TotalHours; // 总小时
  double minutes = timespan.TotalMinutes; // 总分钟
  double seconds = timespan.TotalSeconds; // 总秒数
  double milliseconds = timespan.TotalMilliseconds;
  Console.WriteLine(+hours + " " + minutes + " " + seconds + " " + milliseconds);
  Console.ReadKey();

对象转换成Byte,和Byte转成对象公用方法。

 /// <summary> 
 /// 将一个object对象序列化,返回一个byte[]   
 /// </summary> 
 /// <param name="obj">能序列化的对象</param>   
 /// <returns></returns> 
 public static byte[] ObjectToBytes(object obj)
 {
  byte[] buff;
  using (MemoryStream ms = new MemoryStream())
  {
   IFormatter iFormatter = new BinaryFormatter();
   iFormatter.Serialize(ms, obj);
   buff = ms.GetBuffer();
  }
  return buff;
 }

 /// <summary> 
 /// 将一个序列化后的byte[]数组还原   
 /// </summary>
 /// <param name="Bytes"></param>   
 /// <returns></returns> 
 public static object BytesToObject(byte[] Bytes)
 {
  using (MemoryStream ms = new MemoryStream(Bytes))
  {
   IFormatter formatter = new BinaryFormatter(); return formatter.Deserialize(ms);
  }
 }

注意点:两种方式要分开执行!!!

2.2 响应结果

序列化操作响应时间:

Byte操作响应时间:

我们可以明显看到Byte速度要快于序列化操作,并且Redis获取值没有问题

我们借助Redis客户端工具来看看Redis里面存储的内容:

首先是序列化的内容

然后是Byte的内容

这只是一个简单的测试,后续我还会结合项目实际情况进行测试。如果有写的不对地方欢迎各位指出问题。

总结

到此这篇关于Redis存取序列化与反序列化性能问题的文章就介绍到这了,更多相关Redis存取序列化与反序列化性能内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!


  • 本文相关:
  • redis集群搭建_动力节点java学院整理
  • windows下安装redis服务的图文教程
  • 浅析php分布式中redis实现session的方法
  • redis数据结构之intset的实例详解
  • spring boot+redis实现消息发布与订阅的代码
  • redis学习教程之命令的执行过程详解
  • linux 下redis5.0.0安装教程详解
  • redis实现信息已读未读状态提示
  • redis list列表的详细介绍
  • redis面试必会的题目
  • redis在加入缓存的对象取出来的时候反序列化一定要...
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页redis集群搭建_动力节点java学院整理windows下安装redis服务的图文教程浅析php分布式中redis实现session的方法redis数据结构之intset的实例详解spring boot+redis实现消息发布与订阅的代码redis学习教程之命令的执行过程详解linux 下redis5.0.0安装教程详解redis实现信息已读未读状态提示redis list列表的详细介绍redis面试必会的题目超强、超详细redis数据库入门教程redis常用命令、常见错误、配置技redis操作命令总结redis中5种数据结构的使用场景介64位windows下安装redis教程redis中使用redis-dump导出、导入redis中统计各种数据大小的方法redis常用命令小结让redis在你的系统中发挥更大作用centos 6.6下redis安装配置记录解密redis助力双11背后电商秒杀系统(推荐详解redis数据结构之压缩列表redis集群的离线安装步骤及原理详析redis中5种数据结构的使用场景介绍详解redis的慢查询日志redis中key的设置方法步骤redis分布式锁的正确实现方法总结redis数据结构之intset的实例详解windows环境部署redis集群redis锁机制介绍与实例
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved