基于async/non-blocking高性能redis组件库BeetleX.Redis
BeetleX.Redis
是基于async/non-blocking
模式实现的高性能redis
组件库,组件支持redis基础指令集,并封装更简便的List
,Hashset
和Subscribe
操作。除了在基础操作功能上,组件还提供多服务备份方式和多连接池机制,从而让组件提供高可用和高性能的访问方案;在数据格式上组件默认集成了json
和protobuf
可以根据自己的需求来选择相应的存储格式。接下来大概看一下组件的性能和应用功能。
性能
针对Order结构进行一个GET/SET
性能测试,分别测试BeetleX
和StackExchange
在这两个操作下不同线程的压测,由于在8以上线程数测试StackExchange
经常抛timeout错误....,所以只测了1,2和4线程情况。详细测试代码:https://github.com/IKende/BeetleX.Redis/tree/master/PerformanceTest(代码里集成了一个轻巧的性能测试功能类,用起来非常方便,只需要简单编写测试用例就可以列表出测试时间和并发等相关数据,以下测试结果列表由这个测试类输出。)
- 测试数据结构
{"OrderID":,"CustomerID":"RICSU","EmployeeID":,"OrderDate":"1996-07-12T00:00:00","RequiredDate":"1996-08-09T00:00:00","ShippedDate":"1996-07-15T00:00:00","ShipVia":,"Freight":148.33,"ShipName":"Richter Supermarkt","ShipAddress":"Starenweg 5","ShipCity":"Genève","ShipPostalCode":"","ShipCountry":"Switzerland"}
- Beetlex
await RedisDB.Set(item.OrderID.ToString(), item);
await RedisDB.Get<Order>(i.ToString());
- StackExchange
await RedisDB.StringSetAsync(item.OrderID.ToString(), Newtonsoft.Json.JsonConvert.SerializeObject(item));
var data = await RedisDB.StringGetAsync(i.ToString());
var item = Newtonsoft.Json.JsonConvert.DeserializeObject<Northwind.Data.Order>(data);
- 测试结果
-------------------------------------------------------------------------------
|Name | Round| Threads| Count| Use time(s)| Sec|
-------------------------------------------------------------------------------
|BeetleX_SET | | | | 5.22| |
-------------------------------------------------------------------------------
|StackExchange_SET | | | | 6.97| |
-------------------------------------------------------------------------------
|StackExchange_Sync_SET | | | | 6.62| |
-------------------------------------------------------------------------------
|BeetleX_GET | | | | 5.41| |
-------------------------------------------------------------------------------
|StackExchange_GET | | | | 7.48| |
-------------------------------------------------------------------------------
|StackExchange_Sync_GET | | | | 7.09| |
-------------------------------------------------------------------------------
|BeetleX_MGET | | | | 7.03| |
-------------------------------------------------------------------------------
|StackExchange_MGET | | | | 8.69| |
-------------------------------------------------------------------------------
|StackExchange_Sync_MGET | | | | 8.36| |
-------------------------------------------------------------------------------
|BeetleX_SET | | | | 2.55| |
-------------------------------------------------------------------------------
|StackExchange_SET | | | | 3.97| |
-------------------------------------------------------------------------------
|StackExchange_Sync_SET | | | | 3.56| |
-------------------------------------------------------------------------------
|BeetleX_GET | | | | 2.78| |
-------------------------------------------------------------------------------
|StackExchange_GET | | | | 4.1| |
-------------------------------------------------------------------------------
|StackExchange_Sync_GET | | | | 3.72| |
-------------------------------------------------------------------------------
|BeetleX_MGET | | | | 3.59| |
-------------------------------------------------------------------------------
|StackExchange_MGET | | | | 4.75| |
-------------------------------------------------------------------------------
|StackExchange_Sync_MGET | | | | 4.55| |
-------------------------------------------------------------------------------
|BeetleX_SET | | | | 2.04| |
-------------------------------------------------------------------------------
|StackExchange_SET | | | | 2.37| |
-------------------------------------------------------------------------------
|StackExchange_Sync_SET | | | | 2.15| |
-------------------------------------------------------------------------------
|BeetleX_GET | | | | 2.14| |
-------------------------------------------------------------------------------
|StackExchange_GET | | | | 2.58| |
-------------------------------------------------------------------------------
|StackExchange_Sync_GET | | | | 2.24| |
-------------------------------------------------------------------------------
|BeetleX_MGET | | | | 2.49| |
-------------------------------------------------------------------------------
|StackExchange_MGET | | | | 3.06| |
-------------------------------------------------------------------------------
|StackExchange_Sync_MGET | | | | 2.76| |
-------------------------------------------------------------------------------
组件使用
组件默认就支持数据对象操作,而数据存储的格式则由相应创建的DB数据类型决定,所以在使用和处理数据上都比较方便。
创建数据库
RedisDB DB = new RedisDB();
DB.AddWriteHost("192.168.2.19");
// set password
DB.AddWriteHost("192.168.2.19").Password="";
Json 数据库
RedisDB DB = new RedisDB(, new JsonFormater());
Protobuf 数据库
RedisDB DB = new RedisDB(, new ProtobufFormater());
基础操作
await DB.Decr("mykey")
await DB.Decrby("mykey", );
await DB.Del("mykey");
await DB.Dump("mykey");
await DB.Exists("mykey", "order");
await DB.Expire("mykey", );
await DB.Expireat("mykey", );
await DB.Get<string>("mykey");
await DB.GetBit("mykey", );
await DB.GetRange("mykey", -, -);
await DB.GetSet<string>("mycounter", );
await DB.Incr("mykey");
await DB.Incrby("mykey", );
await DB.IncrbyFloat("mykey", 0.1f);
await DB.Keys("t??");
await DB.MGet<string, string>("key1", "key2");
await DB.MGet<string, string, string>("key1", "aaa", "key2");
await DB.MSet(m => m["key1", "hello"]["key2", "world"]);
await DB.MSetNX(m => m["key1", "hello"]["key2", "there"]);
await DB.Move("one", );
await DB.PSetEX("mykey", , "hello");
await DB.Persist("mykey");
await DB.Pexpire("mykey", );
await DB.Pexpireat("mykey", );
await DB.Ping();
await DB.PTtl("mykey");
await DB.Randomkey();
await DB.Rename("mykey", "myotherkey");
await DB.Renamenx("mykey", "myotherkey");
await DB.Set("test", "henryfan");
await DB.SetBit("mykey", , false);
await DB.SetEX("mykey", , "hello");
await DB.SetNX("mykey", "hello");
await DB.SetRange("key1", , "redis");
await DB.Strlen("key1");
await DB.Type("key2");
列表操作
创建列表
var list = DB.CreateList<Employee>("employees");
列表操作
await list.BLPop();
await list.BRPop();
await list.BRPopLPush("List2");
await list.Index();
await list.Insert(true, GetEmployee(), GetEmployee());
await list.Len();
await list.Pop();
await list.Push(GetEmployee());
await list.Push(GetEmployee(), GetEmployee());
await myotherlist.PushX(GetEmployee());
await list.Rem(-, GetEmployee());
await list.Set(-, GetEmployee());
await list.Trim(, -);
await list.RPop();
await list.RPopLPush("myotherlist");
await list.RPush(GetEmployee());
await list.RPush(GetEmployee(), GetEmployee());
await list.RPushX(GetEmployee());
await list.Range(-, );
HashTable结构
创建
var table = DB.CreateHashTable("myhash");
相关操作
await table.Del("emp1");
await table.Exists("emp1");
await table.Get<Employee>("emp1");
await table.Keys();
await table.Len();
await table.Get<Employee, Order>("emp", "order");
await table.Get<Employee, Order, Customer>("emp", "order", "customer");
await table.MSet(m => m["field1", GetEmployee()]["field2", GetCustomer()]);
await table.Set("field1", GetEmployee());
await table.SetNX("field", GetEmployee());
订阅
创建订阅
var sub = db.Subscribe();
sub.Register<Employee>("test1");
sub.Receive = (o, e) =>
{
Console.WriteLine($"[{DateTime.Now}]{e.Channel}-{e.Type}:{e.Data}");
};
sub.Listen();
通过Retister
方法注册订阅频道,在注册的时候必须指定数据类型,对象反序列化的格式依据库数据的格式类型。
await DB.Publish("test1", GetEmployee(i));
以上是发布消息到频道
总结
以上是BeetleX.Redis
现有版本的功能,集群功能暂没有实现;但提供主备功能可以根据自己的需要添加多个WriteHost或ReadHost,默认连接池机制随意应对高并发应用;组件希望打造一个高性能简便的Redis .net core组件,但要发挥组件的性能特色就要适应完全基于await的方法进行组件操作。 项目开源地址:https://github.com/IKende/BeetleX.Redis
基于async/non-blocking高性能redis组件库BeetleX.Redis的更多相关文章
- 基于Svelte3.x桌面端UI组件库Svelte UI
Svelte-UI,一套基于svelte.js开发的桌面pc端ui组件库 最近一直忙于写svelte-ui,一套svelte3开发的桌面端ui组件库.在设计及功能上借鉴了element-ui组件库.所 ...
- 【xingorg1-ui】基于vue3.0从0-1搭建组件库(一)环境配置与目录规划
npm地址 github源码 开篇-环境配置 环境配置: 使用vue-cli搭建项目框架,需要用vue3的话,得先把vue-cli的版本升级到vue-cli@5以上 npm install -g @v ...
- 基于 Vue.js 的移动端组件库mint-ui实现无限滚动加载更多
通过多次爬坑,发现了这些监听滚动来加载更多的组件的共同点, 因为这些加载更多的方法是绑定在需要加载更多的内容的元素上的, 所以是进入页面则直接触发一次,当监听到滚动事件之后,继续加载更多, 所以对于无 ...
- RSuite 一个基于 React.js 的 Web 组件库
RSuite http://rsuite.github.io RSuite 是一个基于 React.js 开发的 Web 组件库,参考 Bootstrap 设计,提供其中常用组件,支持响应式布局. 我 ...
- 基于Vue的npm组件库
前言(*❦ω❦) 思维导图可能有点高糊,有点太大了,项目和导图文件放到github或giteee上,这个思维导图也是我文章的架构,思维导图是用FeHelper插件生成的,这个是一款开源chrome插件 ...
- 前端组件库 - 搭建web app常用的样式/组件等收集列表(移动优先)
0. 前端自动化(Workflow) 前端构建工具 Webpack - module bundler Yeoman - a set of tools for automating developmen ...
- 16款优秀的Vue UI组件库推荐
16款优秀的Vue UI组件库推荐 Vue 是一个轻巧.高性能.可组件化的MVVM库,API简洁明了,上手快.从Vue推出以来,得到众多Web开发者的认可.在公司的Web前端项目开发中,多个项目采用基 ...
- Vue2.0+组件库总结
转自:https://blog.csdn.net/lishanleilixin/article/details/84025459 UI组件 element - 饿了么出品的Vue2的web UI工具套 ...
- 转:Vue2.0+组件库总结
UI组件 element - 饿了么出品的Vue2的web UI工具套件 Vux - 基于Vue和WeUI的组件库 mint-ui - Vue 2的移动UI元素 iview - 基于 Vuejs 的开 ...
随机推荐
- oracle 登录数据库时报 无监听 的一种解决方式(监听日志文件达到4g默认上限)
问题:登录服务器时 报无监听服务 检查步骤: 1.进入sqlplus查看数据库的状态,显示当前数据库的状态为OPEN 脚本:select status from v$Instance; 2.检查数据库 ...
- JQuery(三)-- AJAX的深入理解以及JQuery的使用
HTTP HTTP http: 超文本传输协议.特点: 简单.快速.灵活.无状态.无连接 URL: 统一资源定位符. 组成:协议名://主机IP:端口号/项目资源地址?传递参数的键值对#锚点 ①ip ...
- C/C++静态代码安全检查工具
静态代码安全检查工具是一种能够帮助程序员自动检测出源程序中是否存在安全缺陷的软件.它通过逐行分析程序的源代码,发现软件中潜在的安全漏洞.本文针对 C/C++语言程序设计中容易存在的多种安全问题,分别分 ...
- windows下安装mysql驱动mysql-python
Windows下直接pip安装会出错 解决方案 到Python Extension Packages for Windows - Christoph Gohlke 下载MySQL_python‑1.2 ...
- 5月2日——iOS11定位失效问题
所存在的问题: (1)定位不能正常使用 (2)首次安装APP 时 "是否允许使用定位信息" 系统提示框不显示 iOS定位失效原因: 因为苹果现在增加了一项新的隐私保护功能 NSL ...
- Spring Boot实战笔记(四)-- Spring常用配置(事件Application Event)
一.事件(Application Event) Spring的事件为Bean和Bean之间的消息通信提供了支持.当一个Bean处理完一个任务之后,希望另一个Bean知道并能做相应的处理,这时我们就需要 ...
- Oracle聚合函数
max(),min(),avg(),sum() 其中 avg(),sum()只能操作数字 , max(),min()能操作数字.日期.字母 等.
- 海量信息库,查找是否存在(bloom filter布隆过滤器)
Bloom Filter(布隆过滤器) 布隆过滤器用于测试某一元素是否存在于给定的集合中,是一种空间利用率很高的随机数据结构(probabilistic data structure),存在一定的误识 ...
- Java 8 基础API的一些小的该进
Java8是一个较大改变的版本,包含了API和库方面的修正,它还对我们常用的API进行很多微小的调整, 下面我会带你了解字符串.集合.注解等新方法. 字符串 经常会遇到这样一种情况, 需要将一组字符串 ...
- 高效开发 Web 单页应用解决方案
于 2017 年初,有在 Github 建立并维护一个项目:Vue Boilerplate Template,欲成就一款开箱即用 Vue + Webpack 的脚手架模版:其目标与宗旨是:根据以往经验 ...