Tendis 分布式高性能 KV 存储数据库开源项目

我要开发同款
白开水不加糖2020年12月21日
90阅读
开发技术C/C++
所属分类缓存服务器、服务器软件、NoSQL数据库
授权协议GPL

作品详情

Tendis是腾讯互娱CROSDBA团队&腾讯云数据库团队自主设计和研发的分布式高性能KV存储数据库,兼容Redis核心数据结构与接口,可提供大容量、低成本、强持久化的数据库能力,适用于兼容Redis协议、需要大容量且较高访问性能的温冷数据存储场景。Tendis目前已经被应用到腾讯内、外部大型项目中。

集群架构

Tendis使用去中心化集群架构,每个数据节点都拥有全部的路由信息,用户可以访问集群中的任意节点,并且通过redis的move协议,最终路由到正确的节点。

每个Tendis节点维护各自的slot数据,任意两个master节点之间的slot不重复,master节点之间支持基于slot的数据搬迁,主备节点之间通过binlog实现数据复制。

所有节点之间通过gossip协议进行通讯,类似于rediscluster的分布式实现,所有节点通过gossip协议通讯,可指定hashtag来控制数据分布和访问,使用和运维成本极低。

适用场景

兼容Redis协议,需要大容量且较高访问性能的温冷数据存储场景

适合成本为主要考虑因素,业务数据有高持久化要求的业务场景

解决原生Redis固有的fork问题而预留部分内存问题

主要特性兼容Redis协议。完全兼容redis协议,支持redis主要数据结构和接口,兼容大部分原生Redis命令。持久化存储。使用rocksdb作为存储引擎,所有数据以特定格式存储在rocksdb中,最大支持PB级存储。去中心化架构。类似于rediscluster的分布式实现,所有节点通过gossip协议通讯,可指定hashtag来控制数据分布和访问,使用和运维成本极低。水平扩展。集群支持增删节点,并且数据可以按照slot在任意两节点之间迁移,扩容和缩容过程中对应用运维人员透明,支持扩展至1000个节点。故障自动切换。自动检测故障节点,当故障发生后,slave会自动提升为master继续对外提供服务。Tendis冷热混合存储关键组件。得益于Tendis存版的设计和内部优化,Redis和Tendis存储版可以一起工作成为Tendis冷热混合存储。混合存储区非常适用于KV存储场景,并平衡了性能和成本。对于redis占用大量存储空间的冷数据降冷后可以最多减少80%的成本,同时保证了热数据在redis的访问性能。项目规划

持续完善对Redis的兼容性,包括支持LUA等命令

进一步提升Tendis的性能,减少rocksdb本身的性能抖动问题。

探索更多软硬结合方案,基于新硬件特性,发挥更大的数据库性能。

支持异构数据互通能力,降低异构数据库的迁移成本

运维管理能力全面提升,PASS能力持续增强

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论