暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

内存数据库选型之Redis与VoltActiveData比较

VoltDB中文社区 2022-04-08
840

依靠内存来存储数据的数据库管理系统,也称为内存数据库,成为解决高并发、低时延数据管理需求的技术路线。近年来,随着动态随机存储 器  (DRAM)  容量的上升和单位价格的下降,使大量数据在内存中的存储和处理成为可能,越来越多的内存数据库管理软件  (IMDB)  逐渐成熟。

  在金融、通信行业的业务场景中,内存数据库的运用越来越深入,不断有新的业务需求、性能要求被提上日程。面对丰富的IMDB产品,如何在 明确业务需求的基础上选择更适合自己的IMDB产品?这里我们选择业界普遍使用的Redis与VoltActiveData(以下简称VOLT)做一个多方位的比较,希望能帮助大家更加了解不同IMDB产品的特性和差异点,能根据自己的业务特征做好技术方案选型。

Client接入DB集群方式比较
 Redis


常用方案如通过proxy来寻址分片,集群 扩缩容对业务层不透明。

 VOLT


透明接入任意node,系统内部派发分 片事务。

与源数据库的数据同步
 Mysql同步数据到Redis


通过JedisCluster优化 - 管道(pipeline)模式导入,数据量大的情况下会造成内存溢出的情况,超百万数据要分批次执行。

 Mysql同步数据到VOLT


执行连接mysql脚本可直接同步数据至VOLT。


 Redis同步数据到Mysql


通过异步队列方式将数据同步至MySQL:

 VOLT同步数据到Mysql


执行连接mysql脚本可直接同步数据至VOLT:
Step1 在VOLT中创建流:

Step2 在存储过程中调用流:

事务支持
 Redis事务


Redis只支持单节点事务,集群模式下需要redis+lua脚本配合使用,lua一般采c/c++来编写。

 VOLT事务


VOLT 是一个完全符合 ACID 的关系型数据库,它使应用程序开发人员不必在自己的应用 程序中开发代码来执行事务和管理回滚。


SQL标准化
 Redis实现


Redis属于NoSql系列的数据库,它的存储结构是Key-Value,它并不像关系数据库那样提供 任何的SQL,像排序、聚合函数、  sql语句无法通过sql查询实现。


例:实现排序
只能通过有序集合(sorted set)组合score+时间的方法组合实现


 VOLT实现


VOLT使用标准SQL,包括CREATE INDEX,CREATETABLE,CREATEVIEW,SELECT,INSERT,UPDATE,DELETE操作等。学习成本和代码迁移成本很低,代码复用程度高,已经使用SQL 实现的应用,可以相对容易的迁移到VOLT。 
同时VOLT还支持用户自定义函数,通过  Java编写并导入数据库,   用户自定义函数能在SQL语句中使用。
例:实现排序


热部署
 Redis实现版本迭代


在项目中编写代码实现功能,版本迭代需要重新部署服务器。


 VOLT实现版本迭代


VOLT通过编写存储过程实现,无需重启应用服务器,重新编译存储过程即可,保证程序的稳定性。

程序中只需调用存储过程:

 双写一致性
  Redis


业务层需要实现机制来保证缓存和数据库的一致。这意味着:

1、开发者需要实现写缓存、写DB这两套接口
2、需要实现缓存miss处理机制
3、需要实现双写,保证数据库和缓存的一致性
4、键值的timeout设置维护

  VOLT


VOLT本身就是RDBMS,或者VOLT可以通过简单配置完成到源数据库的同步。
(可参见上文“VOLT同步数据到Mysql”)

 主从读取一致性保证
  Redis


需要业务层加入实现机制才能保证不读到脏、过期数据。
比如“选择性读主”方案的实现流程为:

  VOLT


DB内部机制保证,对业务层透明。
开箱即用,不需要运维人员选择主从读取方式。

 业务场景实现比较
  • 对象具有多属性的场景

  Redis


单对象多属性的业务场景非常基本。使用 redis存储多属性的情况下,需要业务层  开发两层转换(如使用Hash存储,需要  首先按照对象key查询得到dict,然后按  属性名查询到value)

  VOLT


在一行内解决多属性的读写。

  • 多类型的对象属性关联查询的场景

  Redis


需要业务实现对象的属性解析, 并根据业务需要完成比较匹配、组合属性等。
  VOLT


有RDBMS的优势,使用SQL完成关联查询,解放开发人员。
  • 键值自增自减原子操作

  Redis


用于分布式应用系统的共享计数器,非常效。
  VOLT


使用表列作为计数器,能保证原子操作并同样高效。
 总结



END

如果您希望集成VoltActiveData到您的技术栈中,

请与我们联系!

VoltActiveData中国网站:👇

https://www.voltdb-china.cn/


欢迎扫码添加小助手

进入到我们的官方微信交流群


扫描二维码

加入VoltActiveData交流群

注明公司 实时探讨



最后修改时间:2022-04-22 11:04:20
文章转载自VoltDB中文社区,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论