一般认为NoSQL数据库在性能方面要优于传统的SQL数据库。但是有两个SQL的解决方案宣布:对于大型系统的高可扩展性需求,SQL仍然是可行的解决方案!这两个SQL解决方案分别是MySQL加NoSQL层插件和支持SQL的VoltDB数据库。

MySQL + HandlerSocket

Yoshinori Matsunobu是Sun/Oracle的前雇员,从事MySQL的研发工作,目前是DeNA的首席数据库和基础设施架构师,他以插件的方式为MySQL/InnoDB提供解决方案,可以在一台2.53GHZ、8核CPU、32G内存的Nehalem服务器上把每秒的查询数量(qps)提升到750,000以上。

在同样的硬件环境下,无插件的MySQL只能提供100,000左右的qps,如果使用memecached的话,可以增加到大约400,000。经过对RDBMS的分析,Matsunobu意识到大部分时间都花在SQL的开销上,比如调用MYSQLparse()、MYSQLlex()、make_join_statistics()和JOIN::optimize()等。他写到:

很显然性能降低的原因主要在SQL层,而不是“InnoDB(存储)”层。MySQL必须做很多事情......但memcached/NoSQL是不需要做这些额外工作的。

SQL层的功能包括解析SQL语句、打开/锁定/解锁/关闭表、解决并发问题等。Matsunobu的解决方案就是增加额外的NoSQL层:

我们认为最好的方式就是在MySQL内部实现一个NoSQL的网络服务器。也就是说,编写一个网络服务器作为MySQL的插件(守护插件),用来监听特定端口,接收NoSQL的协议和API,然后通过MySQL内部存储引擎API直接访问InnoDB。这种方式很像NDBAPI,不同的是它可以与InnoDB交互。

他的团队开发了HandlerSocket插件,有了这个插件,MySQL更像一个NoSQL数据库,通过监听一个独立的端口,接收从SQL层来的简单查询请求,例如主键查询,索引扫描和插入/更新/删除。这一变化把数据库性能提升到了750K qps以上。常用端口可以接收处理复杂查询,其核心仍然是SQL数据库。DeNA采用SQL/NoSQL混合的方式取得了成功,据Matsunobu所言,在相同的时间内,这种解决方案把多个memcached和MySQL主从服务器的方案远远甩在了后面。

VoltDB

另一个很有希望的SQL解决方案是VoltDB,这是一个内存中的开源OLTP SQL数据库,能够保证事务的完整性(ACID)。VoltDB是由原Ingres和Postgres的架构师Mike Stonebraker设计的。该数据库主要特征如下:

为了获得最大化吞吐量,数据保存在内存中(而不是在硬盘),这样可以有效消除缓冲区管理。

VoltDB通过SQL引擎把数据分发给集群服务器的每个CPU进行处理。

每个单线程分区自主执行,消除锁定和闩锁的需求。

VoltDB可以通过简单的在集群中增加附加节点的方式实现性能的线性增加。

正如其开发者宣称的那样,该数据库的性能使其成为NoSQL解决方案的有力竞争者:

VoltDB在单节点上可以每秒处理53000个事务请求(TPS),其他DBMS在相同的硬件环境下只能处理1155个。VoltDB的扩展是近似线性的──在12个节点的VoltDB集群上进行同样测试,可以处理560,000 TPS。

基准案例:某个客户的在线游戏在12个节点的VoltDB集群上处理了130万 TPS。

VoltDB还针对NoSQL的键-值存储方式作了基准测试,VoltDB在处理各种键-值存储负载的情况下获得了相同或更好的性能。

除了它的性能,VoltDB的主要优势是可以与SQL用户进行交流,这些SQL用户是很好的资源。

近期还会推出VoltDB的企业版本,包括基于浏览器的数据库管理系统,提供、管理和监控数据库集群。除了免费的社区版本,针对企业版的支持也开始了。

voltdb mysql_MySQL/HandlerSocket和VoltDB:NoSQL的竞争者相关推荐

  1. voltdb mysql_VoltDB安装

    1.什么是VoltDB? 是一个优化吞吐率的高性能集群开源SQLRDBMS(Database Management System),它是一个内存关系型数据库,既获得了nosql的良好可扩展性,高吞吐量 ...

  2. voltdb mysql_voltdb数据库持久性,扩展集群

    之前在git上下载的voltdb,以及在官网下载的社区版voltdb均不支持持久性事务,和扩展集群,今天下载了企业试用版voltdb,安装过程不再赘述,记录一下我的使用过程 持久性测试 以前的 vol ...

  3. voltDB官方文档第三章翻译

    序:本文章是自己再网上查看VoltDB相关资料的时候没有找到太好的学习资料,就前去官方网站上翻译了一部分,约束于个人英语能力有限.实际记录下来的翻译只有第三章. 注:文章翻译自voltDB官方提供的学 ...

  4. VoltDB FAQ

    1.概要信息 1.1VoltDB为何物? VoltDB是为满足极端多的事务处理以及以下需求而设计的关系数据库系统: 可以提供比传统数据库系统好很多的性能. 可以线性扩展. 兼容SQL作为数据库管理接口 ...

  5. 什么都是浮云 唯有云计算灿烂

    福尔斯特说:即将来临的一天,比过去的一年更为悠长.可是这即将来临的一天,无论多么的悠长,终究会流入过去的长河中.把握过去,或许可以成为另一种永恒.回眸过去的2010年,架构的发展或如花开花落如此的相似 ...

  6. 2010年架构社区回顾:悠长的一年

    福尔斯特说:即将来临的一天,比过去的一年更为悠长.可是这即将来临的一天,无论多么的悠长,终究会流入过去的长河中.把握过去,或许可以成为另一种永恒.回眸过去的2010年,架构的发展或如花开花落如此的相似 ...

  7. 2011年企业架构的五个范畴

    作者:机房360 出处:比特网 责编:罗晓娟 1.云计算:依旧灿烂 在过去的几年里,整个IT行业最热的词语无疑首推"云".凡是与云有关的产品,公司,技术与论题,都会得到极大的关注, ...

  8. What Is New About NewSQL(NewSQL的独到之处)?

    文本源自:https://softwareengineeringdaily.com/2019/02/24/what-is-new-about-newsql/ https://cloud.tencent ...

  9. Java 架构师学习路线

    Java 架构师学习路线 一. 框架源码专题 1. 应用框架Spring 1.1. Spring IOC源码剖析 1.2. Spring AOP 源码剖析 1.3. Spring MVC 源码剖析 1 ...

最新文章

  1. 2021年春季学期-信号与系统-第四次作业参考答案-第三小题
  2. Python离线安装依赖包
  3. python 调用sqldr_sqlldr并发
  4. 进阶学习(3.6) Prototype Pattern 原型模式
  5. android手势操作滑动效果触摸屏事件处理
  6. Wcf 双工通信的应用
  7. Httpwatch 工具介绍
  8. Ruby之旅—Ruby的Hello World
  9. Java zip 压缩 文件夹删除,移动,重命名,复制
  10. MySQL复制常见问题处理
  11. word List 06
  12. php调用mysql加密函数_PHP MySQL应用中使用XOR运算加密算法分享
  13. 使用pip安装requests模块(超级简单)+ pip升级失败问题的解决
  14. [C++][基础]8_容器
  15. 填表法解“银行家算法”问题
  16. 安装Google版本的金山词霸会导致播放Silverlight视频的时候IE或者是FF崩溃
  17. Gartner首发中国数据库市场指南,巨杉数据库代表数据库领域厂商入选
  18. 【下载】无线电杂志上下册合集2006-2011
  19. 开源阅读书源_【阅读】一款开源的强大的看书软件!amp;超多书源。
  20. 爬虫ip代理,打码平台推荐

热门文章

  1. 用撸Arduino的方法撸STM32F103xx
  2. 社工库网址与制作方法
  3. sharepoint页面嵌入_在SharePoint 2010页面中嵌入SWF文件
  4. printf 指针地址_数组指针和指针数组
  5. Android开发之API29以上Environment.getExternalStoragePublicDirectory废弃的问题
  6. php switch 函数,php switch case用法与实例教程
  7. 深入一致性哈希(Consistent Hashing)算法原理
  8. 张腾:腾讯云融合通信应用场景及案例分享
  9. STM32学习之路-感觉自己走到了一个天大的坑里了!
  10. Android 自定义View消除锯齿实现图片旋转,添加边框及文字说明