你是否正在使用 Redis 作为您的数据结构存储,享受它的高性能、高可用的特性?如果是这样,那么你可能会对 KeyDB 感兴趣。

什么是 KeyDB?

KeyDB 一个由 Snap 提供支持、专为扩展而构建的开源数据库。它是 Redis 的高性能分支,专注于多线程、内存效率和高吞吐量。KeyDB 采用 MVCC 体系结构,允许您执行 KEYS 和 SCAN 等查询,而不会阻塞数据库并降低性能。KeyDB 保持与 Redis 协议、模块和脚本的完全兼容性,这包括脚本和事务的原子性保证。由于 KeyDB 与 Redis 开发保持同步,KeyDB 是 Redis 功能的超集,这使得 KeyDB 成为现有 Redis 理想的替代品。

项目地址:https://docs.keydb.dev/
源码地址:https://github.com/Snapchat/KeyDB

KeyDB 独有特性

除了与 Redis 相同的功能外,KeyDB 还提供了一些独有的特性,例如:

  • 无阻塞架构:采用一种 MVCC 体系结构,允许你可以查询数据库的单个快照,从而避免阻塞 SCAN 和 KEYS 等调用。这样可以大规模并发调用此类查询,而不会降低现有工作负载的整体性能。
  • 跨区域主动复制:这是一种新的复制模式,允许你在多个主节点之间进行双向异步复制。这样可以实现跨区域的多主站支持,提高数据可用性和一致性,无需哨兵监视节点进行故障转移。
  • 子项过期:这是一种新的过期机制,允许你对集合中的成员设置过期时间。这样可以实现更细粒度的数据管理和清理。
  • TLS加密:这是一种新的安全机制,为你的数据提供 TLS(传输层安全)支持。KeyDB 的 TLS 性能是 Redis + TLS 的 7 倍,并且不需要任何额外的配置或证书。
  • JavaScript 模块:这是一种新的扩展机制,让你可以使用 JavaScript 来编写自定义的命令和逻辑。JavaScript 模块基于 V8 引擎构建,比 Lua 更快,并且支持许多 Node.js 模块。

KeyDB 性能测试

在同一硬件上,KeyDB 可以实现比 Redis 高得多的吞吐量。主动复制简化了热备盘故障切换,使你能够轻松地跨副本分布写入操作,并使用简单的基于 TCP 的负载平衡/故障转移。KeyDB 的更高性能允许你在更少的硬件上做更多的事情,从而降低运营成本和复杂性。

下图为Redis、TLS 和多线程 KeyDB 基准测试比较:

测试显示,在 Redis 6(单线程)上启用 TLS 的情况下,测量值下降了 36%。但是,如果你以前使用过 I/O 线程功能,则可能会看到性能下降 61%,因为使用 TLS 不支持 I/O 线程。

下图为Redis、TLS 和多线程 KeyDB 延迟基准测试比较(数值越低越好):

可以看到,使用 TLS 时,这些负载下的延迟明显更高。KeyDB 不仅在非常高的容量下提供服务,而且延迟也比使用 TLS 的 Redis 低 7 倍。

下图为使用 YCSB 对 Redis 6 多线程 I/O 与 Elasticache 和 KeyDB 进行吞吐量测试比较:

很明显,KeyDB 在每个测试的工作负载下都实现了最高的吞吐量。Elasticache 排在第二位,其次是 Redis 6。可以注意到,在没有 I/O 线程的情况下,Redis 6 仍然比版本5快。

下图为使用 YCSB 对 Redis 6 多线程 I/O 与 Elasticache 和 KeyDB 进行延迟测试比较(以微秒为单位,值越低越好):

上面显示的趋势表明,当实例接近其容量吞吐量时,延迟会显著增加。KeyDB 可以处理比 Redis 6 高得多的吞吐量,并且略高于 Elasticache,因此能够在更高的负载下保持较低的延迟。

KeyDB、Elasticache 和 Redis 6 在轻度到中等流量下都有类似的延迟。直到容量开始达到更高的负载,才能看到差异。

更多测试内容请移步这里查看:https://docs.keydb.dev/blog

如何使用 KeyDB?

由于 KeyDB 与 Redis完全兼容,使得它非常容易使用,我们可以像 Redis 一样来使用它。来做一个简单的示例,演示如何连接到 KeyDB,设置和获取一个字符串值,以及使用 EXPIREMEMBER 命令来设置子项过期。

KeyDB命令文档:https://docs.keydb.dev/docs/commands/#expiremember

首先,从 Docker Hub 拉取 KeyDB 的镜像并运行:

# 拉取 KeyDB 的镜像
docker pull eqalpha/keydb # 运行 KeyDB 的容器
docker run -p 6379:6379 -d eqalpha/keydb

然后,创建一个控制台应用程序,安装 StackExchange.Redis 库:

# 创建一个控制台应用程序
dotnet new console -o KeyDBDemo # 安装 StackExchange.Redis 库
nuget install StackExchange.Redis

然后,编辑 Program.cs 文件,添加以下代码:

using StackExchange.Redis;
public class KeyDBDemo
{
private static void Main(string[] args)
{
// 创建一个连接到本地Redis实例的连接器
ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
// 获取一个数据库对象
IDatabase db = redis.GetDatabase(); // 设置一个字符串值,键为 "name",值为 "Bing"
db.StringSet("name", "Bing"); // 获取键为 "name" 的字符串值
var name = db.StringGet("name"); // 打印结果
Console.WriteLine($"The name is {name}"); // 设置一个集合值,键为 "fruits",值为 ["apple", "banana", "orange"]
db.SetAdd("fruits", new RedisValue[] { "apple", "banana", "orange" }); // 为集合中的成员 "apple" 设置过期时间为 5 秒
db.Execute("EXPIREMEMBER", "fruits", "apple", 5); // 获取键为 "fruits" 的集合值
var fruits = db.SetMembers("fruits"); // 打印结果
Console.WriteLine($"The fruits are {string.Join(", ", fruits)}"); // 等待 5 秒后,再次获取键为 "fruits" 的集合值
Thread.Sleep(5100);
fruits = db.SetMembers("fruits"); // 打印结果
Console.WriteLine($"The fruits are {string.Join(", ", fruits)}"); // 关闭连接
redis.Close();
}
}

最后,运行程序,可以得到以下结果:

The name is Bing
The fruits are banana, apple, orange
The fruits are banana, orange

写作不易,转载请注明文章出处,否则禁转!!!

感谢阅读,点赞+分享+收藏+关注
文章出自猿惑豁微信公众号

Redis的速度不够用?为什么你应该考虑使用 KeyDB,一个更快、更强大、更灵活的开源数据库的更多相关文章

  1. 比Redis更快:Berkeley DB面面观

    比Redis更快:Berkeley DB面面观 Redis很火,最近大家用的多.从两年前开始,Memcached转向Redis逐渐成为潮流:而Berkeley DB可能很多朋友还很陌生,首先,我们简单 ...

  2. 你的以太网速度足够快吗?四种更快的速度正在路上······

    以太网的未来将远远超越下一个最快速度:为无处不在的网络协议绘制路径的网络project师们正在寻找新版本号来服务于各种应用程序. 在上周六的以太网联盟(一个行业组织,用于促进IEEE以太网标准)会议上 ...

  3. 超越halcon速度的二值图像的腐蚀和膨胀,实现目前最快的半径相关类算法(附核心源码)。

    我在两年前的博客里曾经写过 SSE图像算法优化系列七:基于SSE实现的极速的矩形核腐蚀和膨胀(最大值和最小值)算法  一文,通过SSE的优化把矩形核心的腐蚀和膨胀做到了不仅和半径无关,而且速度也相当的 ...

  4. 更快的Maven来了,我的天,速度提升了8倍!

    周末被 maven-mvnd 刷屏了,于是我也下载了一个 mvnd 体验了一把.虽然测试的数据都是基于我本地项目,不具备普适性和权威性,但也足以说明问题.它的测试结果远远超出我的预期,下面一起来看. ...

  5. Go1.7改善了编译速度并且会生成更快的代码

    Go1.7的开发周期正在接近它的下一个里程碑,Go的提交者Dave Cheney报告了子即将发布的版本中,团队成员在语言工具链上的努力. Cheney称,基于当前的开发状态,Go1.7将会很容易就成为 ...

  6. JQuery动画插件Velocity.js发布:更快的动画切换速度

    5月3日,Julian在其GitHub上发布了Velocity.js.Velocity.js是一款动画切换的jQuery插件,它重新实现了jQuery的$.animate()方法从而加快动画切换的速度 ...

  7. Velocity.js发布:更快的动画切换速度

    Velocity.js是一款动画切换的jQuery插件,它重新实现了jQuery的$.animate()方法从而加快动画切换的速度.Velocity.js只有7k的大小,它不仅包含了$.animate ...

  8. 我发起了一个 .Net Core 平台上的 分布式缓存 开源项目 ShareMemory 用于 取代 Redis

    Redis 的 安装 是 复杂 的, 使用 是 复杂 的, Redis 的 功能 是 重型 的, Redis 本身的 技术实现 是 复杂 的 . Redis 是用 C 写的, C 语言 编写的代码需要 ...

  9. 更快的速度、更好的服务——易普优APS云排程

    众所周知软件执行效率受制于硬件性能,市面上的APS产品多为单机版本,企业要应用好APS,保证紧急插单.计划下发全程无忧,用户电脑硬件性能是不容忽视的一大瓶颈.APS的直接用户是车间管理人员.计划员,而 ...

  10. 谷歌Chrome 27测试版已经发布 更快的浏览速度

    谷歌已经发布了Chrome 27测试版浏览器,为普通用户带来了大约提升为5%的网页浏览速度.用户已经可以在Chrome测试网页下载到最新的更新了.我们已经对这版更新做了一个全面的快速测试,让我们看看究 ...

随机推荐

  1. 谁在以太坊区块链上循环交易?TuGraph+Kafka的0元流图解决方案

    都在说数据已经成为新时代的生产资料. 但随着大数据和人工智能等技术的发展,即便人们都知道数据的价值日益凸显,却无法凭借一己之力获取和分析如此大规模的数据. 要想富,先修路.要想利用新时代的数据致富,也 ...

  2. 搭载ChatGPT之后的表格插件又有哪些新的改变——Function calling增强

    摘要:本文由葡萄城技术团队于博客园原创并首发.葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 在<大火的ChatGPT与SpreadJS结合会有哪些意想不到的效果>一文中提 ...

  3. python笔记:第六章函数&方法

    1.系统函数 由系统提供,直接拿来用或是导入模块后使用 a = 1.12386 result = round(a,2) print(result) > 1.12 2.自定义函数 函数是结构化编程 ...

  4. 《架构整洁之道》学习笔记 Part 2 编程范式

    计算机编程发展至今,一共只有三个编程范式: 结构化编程 面向对象编程 函数式编程 编程范式和软件架构的关系 结构化编程是各个模块的算法实现基础 多态(面向对象编程)是跨越架构边界的手段 函数式编程是规 ...

  5. 2023-07-22:一共有n个项目,每个项目都有两个信息, projects[i] = {a, b}, 表示i号项目做完要a天,但是当你投入b个资源,它就会缩短1天的时间, 你一共有k个资源,你的目

    2023-07-22:一共有n个项目,每个项目都有两个信息, projects[i] = {a, b}, 表示i号项目做完要a天,但是当你投入b个资源,它就会缩短1天的时间, 你一共有k个资源,你的目 ...

  6. XCTF-favorite_number

    题目 (xctf.org.cn) 判断,既要数组强等于,又要首元素不等:php有下标越界溢出漏洞,因此0可以通过整型溢出得到 绕过if判断 playload:stuff[4294967296]=adm ...

  7. .Net Core控制台程序读取Json配置文件

    1 添加依赖(可以直接通过nuget包安装 Microsoft.Extensions.Configuration.Json 这个会依赖其他两个会自动安装依赖的) Microsoft.Extension ...

  8. PostgreSql: 安装与链接

    环境介绍 使用宝塔面板,在阿里云中安装PostgreSql,并使用DataGrip在本地进行链接 postgresql 配置 安装postgresql 在宝塔中安装postgresql 管理器 在此处 ...

  9. Angular: Error: NG0100: ExpressionChangedAfterItHasBeenChecked

    错误原因 当变更检测完成后又更改了表达式的值时,Angular就会抛出ExpressionChangedAfterItHasBeenCheckedError 错误,Angular只会在开发模式下抛出此 ...

  10. 【入门教程】3202年了,还有人没用stable diffusion画过自己的AI小姐姐吗。

    个人绘画作品: 说明 本文主要是讲一下如何安装.使用整合包,以及介绍画真人图片的大模型(介绍的整合包只提供二次元模型,个人不太感兴趣) 通过最简单的介绍帮助大家快速入门,开始画图,不会深入的进行讲解, ...