作死造轮子

Oedis是近段时间为了解决日志型数据如何与Entity Framework的查询整合的问题写的一个Redis的OH /RM。虽然Redis出来蛮久了,各路高手也都提出了实践方案,但是或许是因为Redis本身不需要OH/RM的原因(毕竟NoSQL),所以一开始压根没找到...这就很尴尬了。

由于日志也是一个类,并且保持持续增长,预估400K/d,继续用SQL Server的话感觉有点不大对,所以转向Redis,但是要往Redis里存储数据需要自行设计一系列然后撰写一次性代码...自打写完不少有违设计模式的项目就觉得重复代码很恶心,所以希望能通过一套框架(或者说一套代码)将数据自动解析并存储到Redis,查询的时候也能正确序列化回来。

由于真的找不到类似的东西,所以就自己造轮子了...Oedis在底层使用了不少反射还有程序集方法,自己想着都觉得效率有点坑...不过还是能满足自身需求和目标的。在数据库连接上试了几个后选择了StackExchange.Redis驱动,一开始选择的是非常轻量的Sider,不过用起来似乎遇到了些有趣的问题...所以就转到了StackExchange.Redis。

由于这只是一个解决整合EF与Redis和当前代码问题的解决方案,所以如果要求极致性能,还请使用直接操纵Redis的方法。

一开始准备实现IQueryable,结果发现有些繁琐...也发现这也不需要生成SQL并且Redis也不是关系型数据库,检索本来就是受限的,所以就用表达式树来处理Where的predicate。

项目地址

在Github上托管的公共版本

简易安装

在项目中使用 Nuget 引用:

Install-Package Oedis

Oedis 需要 StackExchange.Redis 作为 Redis 驱动。

用于 Oedis 的 POCO 类

Oedis 的 POCO 类可以与 Entity Framework 一同使用。只需要使用 [Master] 标注主属性,[Reference] 标注参考属性,将需要排除在外的属性使用 [Except] 标记。

如果我们需要创建一个 Report 类,那么可以像这样:

public class Report
{
[Master]
[Key]
public Int32 Id { get; set;} [Reference]
[NotMapped]
public Guid Case_Id { get; set; } [Except]
public virtual Case Case { get; set;} public String Context { get; set; }
}

你可能发现我们是不支持导航属性的。直言不讳,确实没做这个功能。如果你需要的话或许可以考虑一起实现?

配置 Oedis 上下文

没啥说的,参考 Entity Framework 就好了:

class OedisContext : Oedis.OedisContext
{
public OedisContext() : base() { }
public RedisSet<Report> Reports { get; set; }
}

开始使用

创建上下文对象

var OS = new OedisContext();

插入一个对象

OS.Reports.Add(new Report
{
Id = 0,
Product = "EF",
Rid = Guid.NewGuid()
});

移除一个对象

OS.Reports.Remove(
OS.Reports.Find(Guid.Parse(guidstr))
);

移除很多对象

OS.Reports.Remove(OS.Reports
.Where(x=>x.Rid==new Guid(guidstr)));

上面的写法是清空一个引用属性对应的所有对象,不推荐那样的写法,建议:

OS.Reports
.Clear(x=>x.Rid==new Guid(guidstr));

当前需要注意的信息

  • Oedis 不支持多主属性,至少现在不支持,你或许可以换个方案?
  • Oedis 将会直接向你的 Redis 数据库中插入数据,所以希望你提供的属性至少都能被转换为 String 类型,或者你可以考虑写一个 ToString() 的方法?
  • 当前版本的 Odeis 只能设置一个参考属性。如果你设定了多个,可能某些属性会被忽略。
  • 用于判定的 Lambda 表达式当前是受限的,暂时请不要撰写复杂表达式。

性能表现:



跑成绩的时候0.1和0.2版本混杂了...可能有出入,不过表现出来的成绩应该是差不多的(或许更快,StackExchange.Redis的速度要比Sider快不少)。

介绍Oedis - Redis OH/RM的更多相关文章

  1. Redis的RDB与AOF介绍(Redis DateBase与Append Only File)

    RedisRDB介绍(Redis DateBase) 在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是行话讲的Snapshot快照,它恢复时是将快照文件直接读到内存里 一.是什么? Redis会 ...

  2. 新书介绍 -- 《Redis核心原理与实践》

    大家好,今天给大家介绍一下我的新书 -- <Redis核心原理与实践>. 后端开发的同学应该对Redis都不陌生,Redis由于性能极高.功能强大,已成为业界非常流行的内存数据库. < ...

  3. 介绍一个Redis的WEB 客户端

    http://webd.is/ $ git clone git://github.com/nicolasff/webdis.git                $ cd webdis$ make$ ...

  4. 第四节:Geo类型介绍以及Redis批量操作、事务、分布式锁

    一. Geo类型 1. 类型说明 Geo 是 Redis 3.2 版本后新增的数据类型,用来保存兴趣点(POI,point of interest)的坐标信息.可以实现计算两 POI 之间的距离.获取 ...

  5. 1-NoSQL介绍及Redis安装

    背景 随着互联网的不断发展和软件架构的不断复杂化,同时随着网站访问量的日渐上升,导致传统单机关系型数据库应用已经无法满足人们的需求,在高并发的场景下,频繁的数据库存取操作使得服务器压力剧增,甚至导致服 ...

  6. windows平台下redis安装及配置文件介绍

    1.redis介绍 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(s ...

  7. Redis使用介绍

    Redis 是一个高性能的key-value数据库. redis的出现,很大程度补偿了memcached这类keyvalue存储的不足,在部 分场合可以对关系数据库起到很好的补充作用.它提供了Pyth ...

  8. Redis Cluster架构和设计机制简单介绍

    之前另一篇文章也介绍了 Redis Cluster (link,在文章的后半部分) 今天看到这一篇,简单说一下(http://hot66hot.iteye.com/blog/2050676) 作者的目 ...

  9. 【redis】01Redis的介绍与安装部署

    单元目标: 1.NoSQL介绍 2.Redis的介绍 3.Redis适用场合 4.Redis的安装与部署 5.Redis的数据类型 6.Redis的常用命令 7.Redis的高级应用       通过 ...

随机推荐

  1. js汉语转拼音(全拼、首字母、拼音首字母)

    新建js文件first_alphabet.js // JavaScript Document // 汉字拼音首字母列表 本列表包含了20902个汉字,用于配合 ToChineseSpell //函数使 ...

  2. Flask备注4(Structure)

    Flask备注4(Structure) package 通过Flask可以非常简单的通过一个module(一个py文件)创建一个简单的application.这种简单程序的文件结构如下: /youra ...

  3. Linux内核完全注释阅读笔记1:O(1)时间复杂度查找timeout定时器

    前言 一直有Linux kernel情节,之前也一直在看Linux kernel相关的书和代码,但是每次到最后又由于兴趣转变而荒废了.这次终于静下心来想把Linux内核相关的代码好好看看,算是对自己的 ...

  4. 常用邮件服务器名(POP3,SMTP地址)

    POP3服务器地址:pop3.sina.com.cn(端口:110)SMTP服务器地址:smtp.sina.com.cn(端口:25) sina.cn: POP3服务器地址:pop3.sina.com ...

  5. 【转】Nginx服务器详细配置含注释

    #使用的用户和组 user www www; #指定工作衍生进程数(一般等于CPU的总核数或总核数的两倍) worker_processes 8; #指定错误日志存放的路径,错误日志的记录级别可为de ...

  6. SQL:无法解决 equal to 操作的排序规则冲突。

    更改存储过程的时候,在SQL中出现了 “无法解决 equal to 操作的排序规则冲突”错误,网上搜之,发现是表之间元素创建时排序规则不同(一个是collate Chinese_PRC_CI_AI_W ...

  7. Runloop 深入理解(转)

    RunLoop 是 iOS 和 OSX 开发中非常基础的一个概念,这篇文章将从 CFRunLoop 的源码入手,介绍 RunLoop 的概念以及底层实现原理.之后会介绍一下在 iOS 中,苹果是如何利 ...

  8. JSNO

    JSON 编辑 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了 ...

  9. memcached总结

    Memcached说明文档 Memcached是什么? Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数 ...

  10. SharePoint 2013异常信息的查看

    刚刚学习SharePoint开发的时候,经常遇到一些异常,却不能直接看到详细信息,很郁闷.这里做下简单的整理,方便查找: 1.代码未处理异常出现黄页——”‘/’应用程序中的服务器错误.运行时错误“. ...