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

[经验分享] 怎样在Redis通过StackExchange.Redis 存储集合类型List

[复制链接]

尚未签到

发表于 2017-12-20 15:27:14 | 显示全部楼层 |阅读模式
  StackExchange 是由StackOverFlow出品, 是对Redis的.NET封装,被越来越多的.NET开发者使用在项目中。
  绝大部分原先使用ServiceStack的开发者逐渐都转了过来,由于SS在其新版中不再开源,并对免费版本有所限制。

实际问题
  那么用.NET的开发者会发现,其根本没有对List类型的存储封装,那么要实现一个类似如下需求:
  假如我有一个Customer的模型。
  

    public>{public string FirstName { get; set; }public string LastName { get; set; }public string Address1 { get; set; }public string City { get; set; }public string State { get; set; }  }
  

  

var customers = new List<Customer>();  

  怎样将List<customer> customers 存入Redis中呢?

来龙去脉
  是由于StackExchange.Redis是一个纯客户端的代理,他仅仅实现了Redis自由的功能,并不额外封装其它功能。 也不具备像ORM那样的自动类型匹配。
  他仅仅存储键值对 像string 或者 byte[]。所以你明白了吧,必须序列化存储,用类似Json格式一样。像用第三方NewtonSoft或者是Google公司流行的Protocol Buffers 序列化格式的Protobuf-Net 也是不错的选择。
  Redis支持存储的类型有五种String ,Hash ,List ,Set ,和 Sorted Set, 正如上面说的,这些存储类型全部由字符串构成。
  其中Set类型是没有顺序的,并且值必须唯一, List类型有顺序且允许重复。

解决方案
  如果你仅仅为了缓存存一批量的 List<Customer> 数据, 那么自己封装一个ListGet() 和 ListSet()方法吧。
  我对比过使用 List 和 String 两种类型存储。
  Redis 的List类型和 .NET领域还有所不同,实际上,它是一个双向队列,可以左右插入值。
  所以如果是批量数据插入 那么必须一个个插入, 代码比较简单如下:
  

//封装的ListSet  
public void ListSet<T>(string key, List<T> value)
  
{
  .....
  //下面的database 是redis的数据库对象.
  foreach (var single in value)
  {
  var s = ConvertJson(single); //序列化
  database.ListRightPush(key, s); //要一个个的插入
  
        }
  
}
  
//封装的ListGet
  
public void ListGet<T>(string key)
  
{
  ...
  //ListRange返回的是一组字符串对象
  //需要逐个反序列化成实体
  var vList = database.ListRange(key) ;  
  List<T> result = new List<T>();
  foreach (var item in vList)
  {
  var model = ConvertObj<T>(item); //反序列化
  
           result.Add(model);
  }
  return result;
  
}
  

  当然测试了一下性能,取20W条数据平均时间
  测试效果如下:
DSC0000.png

  获取10000条数据,平均时间大概793.78毫秒.
  当然也必须试一下String 方式的类型存储啦,代码如下:
  

   /// <summary>  /// 存储List
  /// </summary>
  /// <typeparam name="T"></typeparam>
  /// <param name="key"></param>
  /// <param name="value"></param>
  public void ListSet<T>(string key, List<T> value)
  {
  db.StringSet(key, ConvertJson(value));
  }
  /// <summary>
  /// 获取指定key的List
  /// </summary>
  /// <param name="key"></param>
  /// <returns></returns>
  public List<T> ListGet<T>(string key)
  {
  return ConvetList<T>(db.StringGet(key));
  }
  

DSC0001.png

  哇! 结果惊呆了有没有。
  使用String方式 比List方式快至少20倍。
  看来不同的方式性能差别还挺大的。
  String是一次性序列化一次性的反序列化,这其中比List少了逐个插入和获取反序列化的过程。所以作为整体存取还是一个不错的方式。
  至于其余类型的方式,大家也可以去试试。


运维网声明 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-426084-1-1.html 上篇帖子: C#Redis 主从复制 下篇帖子: PHP操作redis
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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