page contents

加强版Redis,又一款国产高性能KV存储数据库开源了!

Tendis是腾讯互娱CROS DBA团队 & 腾讯云数据库团队自主设计和研发的分布式高性能KV存储数据库,兼容Redis核心数据结构与接口。

attachments-2021-01-ZDtBcXFL5ff1261fd22fd.png


项目简介

Tendis是腾讯互娱CROS DBA团队 & 腾讯云数据库团队自主设计和研发的分布式高性能KV存储数据库,兼容Redis核心数据结构与接口。

可提供大容量、低成本、强持久化的数据库能力,适用于兼容Redis协议、需要大容量且较高访问性能的温冷数据存储场景。

Tendis目前已经被应用到腾讯内、外部大型项目中。


集群架构

attachments-2021-01-tzkO60Z75ff1260a67551.png

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

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

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


适用场景

  • 兼容Redis协议,需要大容量且较高访问性能的温冷数据存储场景
  • 适合成本为主要考虑因素,业务数据有高持久化要求的业务场景
  • 解决原生Redis固有的fork问题而预留部分内存问题


主要特性

兼容Redis协议

完全兼容redis协议,支持redis主要数据结构和接口,兼容大部分原生Redis命令。

持久化存储

使用rocksdb作为存储引擎,所有数据以特定格式存储在rocksdb中,最大支持PB级存储。

去中心化架构

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

水平扩展

集群支持增删节点,并且数据可以按照slot在任意两节点之间迁移,扩容和缩容过程中对应用运维人员透明,支持扩展至1000个节点。

故障自动切换

自动检测故障节点,当故障发生后,slave会自动提升为master继续对外提供服务。

Tendis冷热混合存储关键组件

得益于Tendis存版的设计和内部优化,Redis和Tendis存储版可以一起工作成为Tendis冷热混合存储。混合存储区非常适用于KV存储场景,并平衡了性能和成本。对于redis占用大量存储空间的冷数据降冷后可以最多减少80%的成本,同时保证了热数据在redis的访问性能。


项目规划

  • 持续完善对Redis的兼容性,包括支持LUA等命令
  • 进一步提升Tendis的性能,减少rocksdb本身的性能抖动问题。
  • 探索更多软硬结合方案,基于新硬件特性,发挥更大的数据库性能。
  • 支持异构数据互通能力,降低异构数据库的迁移成本
  • 运维管理能力全面提升,PaaS能力持续增强

Tendis目前已在腾讯内外部包括游戏、视频、社交、电商等多个行业提供数据库支撑。感兴趣的童鞋可以去GitHub详细了解一下:

https://github.com/Tencent/Te...


attachments-2021-01-NXoH6UzY5ff125e5c2a83.jpg来源:腾讯开源

  • 发表于 2021-01-03 10:03
  • 阅读 ( 691 )
  • 分类:操作系统

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
Pack
Pack

1135 篇文章

作家榜 »

  1. 轩辕小不懂 2403 文章
  2. 小柒 1478 文章
  3. Pack 1135 文章
  4. Nen 576 文章
  5. 王昭君 209 文章
  6. 文双 71 文章
  7. 小威 64 文章
  8. Cara 36 文章