基于async/non-blocking高性能redis组件库BeetleX.Redis

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 基于async/non-blocking高性能redis组件库BeetleX.RedisBeetleX.Redis是基于async/non-blocking模式实现的高性能redis组件库,组件支持redis基础指令集,并封装更简便的List,Hashset和Subscribe操作。

基于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":10255,"CustomerID":"RICSU","EmployeeID":9,"OrderDate":"1996-07-12T00:00:00","RequiredDate":"1996-08-09T00:00:00","ShippedDate":"1996-07-15T00:00:00","ShipVia":3,"Freight":148.33,"ShipName":"Richter Supermarkt","ShipAddress":"Starenweg 5","ShipCity":"Genève","ShipPostalCode":"1204","ShipCountry":"Switzerland"}
Beetlex
1 await RedisDB.Set(item.OrderID.ToString(), item);
2 await RedisDB.Get(i.ToString());
StackExchange
1 await RedisDB.StringSetAsync(item.OrderID.ToString(), Newtonsoft.Json.JsonConvert.SerializeObject(item));
2 var data = await RedisDB.StringGetAsync(i.ToString());
3 var item = Newtonsoft.Json.JsonConvert.DeserializeObject(data);
测试结果

复制代码

|Name | Round| Threads| Count| Use time(s)| Sec|

|BeetleX_SET | 1| 1| 100000| 5.22| 19157|

|StackExchange_SET | 1| 1| 100000| 6.97| 14357|

|StackExchange_Sync_SET | 1| 1| 100000| 6.62| 15103|

|BeetleX_GET | 1| 1| 100000| 5.41| 18487|

|StackExchange_GET | 1| 1| 100000| 7.48| 13378|

|StackExchange_Sync_GET | 1| 1| 100000| 7.09| 14105|

|BeetleX_MGET | 1| 1| 100000| 7.03| 14216|

|StackExchange_MGET | 1| 1| 100000| 8.69| 11504|

|StackExchange_Sync_MGET | 1| 1| 100000| 8.36| 11963|

|BeetleX_SET | 1| 2| 100000| 2.55| 39246|

|StackExchange_SET | 1| 2| 100000| 3.97| 25199|

|StackExchange_Sync_SET | 1| 2| 100000| 3.56| 28069|

|BeetleX_GET | 1| 2| 100000| 2.78| 35946|

|StackExchange_GET | 1| 2| 100000| 4.1| 24364|

|StackExchange_Sync_GET | 1| 2| 100000| 3.72| 26907|

|BeetleX_MGET | 1| 2| 100000| 3.59| 27871|

|StackExchange_MGET | 1| 2| 100000| 4.75| 21035|

|StackExchange_Sync_MGET | 1| 2| 100000| 4.55| 21976|

|BeetleX_SET | 1| 4| 100000| 2.04| 48956|

|StackExchange_SET | 1| 4| 100000| 2.37| 42220|

|StackExchange_Sync_SET | 1| 4| 100000| 2.15| 46541|

|BeetleX_GET | 1| 4| 100000| 2.14| 46822|

|StackExchange_GET | 1| 4| 100000| 2.58| 38789|

|StackExchange_Sync_GET | 1| 4| 100000| 2.24| 44619|

|BeetleX_MGET | 1| 4| 100000| 2.49| 40238|

|StackExchange_MGET | 1| 4| 100000| 3.06| 32708|

|StackExchange_Sync_MGET | 1| 4| 100000| 2.76| 36264|

复制代码
组件使用
组件默认就支持数据对象操作,而数据存储的格式则由相应创建的DB数据类型决定,所以在使用和处理数据上都比较方便。

创建数据库
RedisDB DB = new RedisDB();
DB.AddWriteHost("192.168.2.19");
// set password
DB.AddWriteHost("192.168.2.19").Password="123456";
Json 数据库
RedisDB DB = new RedisDB(0, new JsonFormater());
Protobuf 数据库
RedisDB DB = new RedisDB(0, new ProtobufFormater());
基础操作
复制代码
await DB.Decr("mykey")
await DB.Decrby("mykey", 5);
await DB.Del("mykey");
await DB.Dump("mykey");
await DB.Exists("mykey", "order");
await DB.Expire("mykey", 10);
await DB.Expireat("mykey", 1293840000);
await DB.Get("mykey");
await DB.GetBit("mykey", 0);
await DB.GetRange("mykey", -3, -1);
await DB.GetSet("mycounter", 0);
await DB.Incr("mykey");
await DB.Incrby("mykey", 10);
await DB.IncrbyFloat("mykey", 0.1f);
await DB.Keys("t??");
await DB.MGet("key1", "key2");
await DB.MGet("key1", "aaa", "key2");
await DB.MSet(m => m"key1", "hello");
await DB.MSetNX(m => m"key1", "hello");
await DB.Move("one", 9);
await DB.PSetEX("mykey", 1000, "hello");
await DB.Persist("mykey");
await DB.Pexpire("mykey", 1500);
await DB.Pexpireat("mykey", 1555555555005);
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", 7, false);
await DB.SetEX("mykey", 10, "hello");
await DB.SetNX("mykey", "hello");
await DB.SetRange("key1", 6, "redis");
await DB.Strlen("key1");
await DB.Type("key2");
复制代码
列表操作
创建列表

var list = DB.CreateList("employees");
列表操作

复制代码
await list.BLPop();
await list.BRPop();
await list.BRPopLPush("List2");
await list.Index(0);
await list.Insert(true, GetEmployee(2), GetEmployee(3));
await list.Len();
await list.Pop();
await list.Push(GetEmployee(1));
await list.Push(GetEmployee(1), GetEmployee(2));
await myotherlist.PushX(GetEmployee(2));
await list.Rem(-2, GetEmployee(1));
await list.Set(-2, GetEmployee(5));
await list.Trim(1, -1);
await list.RPop();
await list.RPopLPush("myotherlist");
await list.RPush(GetEmployee(3));
await list.RPush(GetEmployee(1), GetEmployee(2));
await list.RPushX(GetEmployee(2));
await list.Range(-3, 2);
复制代码
HashTable结构
创建

var table = DB.CreateHashTable("myhash");
相关操作

复制代码
await table.Del("emp1");
await table.Exists("emp1");
await table.Get("emp1");
await table.Keys();
await table.Len();
await table.Get("emp", "order");
await table.Get("emp", "order", "customer");
await table.MSet(m => m"field1", GetEmployee(1));
await table.Set("field1", GetEmployee(1));
await table.SetNX("field", GetEmployee(1));
复制代码
订阅
创建订阅

复制代码

        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
原文地址https://www.cnblogs.com/smark/p/10639573.html

相关文章
|
28天前
|
存储 NoSQL Redis
阿里云高性能数据库Tair(兼容 Redis)收费价格,稳定可靠成本低
阿里云高性能云数据库Tair兼容Redis,提供Redis开源版和Tair企业版,支持多种存储介质与灵活扩展,适用于高并发场景。Tair具备亚毫秒级稳定延迟,保障业务连续性。价格方面,Redis开源版年费从72元起,Tair企业版年费从1224元起,具体费用根据配置不同有所变化。
|
13天前
|
缓存 运维 监控
Redis 7.0 高性能缓存架构设计与优化
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Redis 7.0高性能缓存架构,探索函数化编程、多层缓存、集群优化与分片消息系统,用代码在二进制星河中谱写极客诗篇。
|
5月前
|
缓存 NoSQL Java
Redis+Caffeine构建高性能二级缓存
大家好,我是摘星。今天为大家带来的是Redis+Caffeine构建高性能二级缓存,废话不多说直接开始~
777 0
|
6月前
|
NoSQL 安全 Java
深入理解 RedisConnectionFactory:Spring Data Redis 的核心组件
在 Spring Data Redis 中,`RedisConnectionFactory` 是核心组件,负责创建和管理与 Redis 的连接。它支持单机、集群及哨兵等多种模式,为上层组件(如 `RedisTemplate`)提供连接抽象。Spring 提供了 Lettuce 和 Jedis 两种主要实现,其中 Lettuce 因其线程安全和高性能特性被广泛推荐。通过手动配置或 Spring Boot 自动化配置,开发者可轻松集成 Redis,提升应用性能与扩展性。本文深入解析其作用、实现方式及常见问题解决方法,助你高效使用 Redis。
609 4
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
205 6
|
缓存 NoSQL Java
Redis深度解析:解锁高性能缓存的终极武器,让你的应用飞起来
【8月更文挑战第29天】本文从基本概念入手,通过实战示例、原理解析和高级使用技巧,全面讲解Redis这一高性能键值对数据库。Redis基于内存存储,支持多种数据结构,如字符串、列表和哈希表等,常用于数据库、缓存及消息队列。文中详细介绍了如何在Spring Boot项目中集成Redis,并展示了其工作原理、缓存实现方法及高级特性,如事务、发布/订阅、Lua脚本和集群等,帮助读者从入门到精通Redis,大幅提升应用性能与可扩展性。
217 0
|
11月前
|
缓存 NoSQL PHP
Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出
本文深入探讨了Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出。文章还介绍了Redis在页面缓存、数据缓存和会话缓存等应用场景中的使用,并强调了缓存数据一致性、过期时间设置、容量控制和安全问题的重要性。
205 5
|
存储 消息中间件 NoSQL
Redis 入门 - C#.NET Core客户端库六种选择
Redis 入门 - C#.NET Core客户端库六种选择
368 8
|
存储 缓存 NoSQL
Redis的高性能之谜
Redis的高性能之谜
104 5
|
存储 消息中间件 NoSQL
Redis的单线程设计之谜:高性能与简洁并存
Redis的单线程设计之谜:高性能与简洁并存
134 1