參考资料:

(1) 《OLTP Through the Looking Glass, and What We Found There》

(2) 《The End of an Architectural Era》。VLDB 2007

越来越多的程序猿開始做移动App的开发,真正做底层系统开发的程序猿还是少数。看到国内数据库系统发展的资料不是非常多,我也把自己对当前数据库系统发展的认识写成博文, 和大家分享,希望能够互相学习。

数据库系统的最近发展和分类

随着操作系统发展趋于稳定(不包含移动端OS),越来越的的研究集中在数据库系统的发展上,没有多少人说要又一次做一个操作系统,很多其它的人是在现有的OS上做各式各样的应用。可是过去的10年,是数据库井喷式发展的阶段,各式各样的产品迸发出来,比如文件存储数据库(如MongoDB),列存储数据库(如Vertica), 各种NewSQL数据库(如VoltDB)。之全部有如此的发展,归结于数据量不断高速膨胀,传统数据库在大数据上的处理性能不能满足需求等。

人们趋于去开发针对不同应用类型的数据库,来满足对特定数据处理的需求。在操作系统上开发数据库系统应用非常像是在开发移动App一样。出现了蓬勃似得发展。因为当下Big
Data依然是很火热的话题。在未来的一段时间内。提供底层数据管理服务的数据库,仍旧会是计算机发展比較快的领域之中的一个。

很多人会把数据库系统和其它某些概念混淆在一起,事实上数据库作为一个大的系统。就对眼下市场上产品来讲,能够分好多类:

1. 关系型数据库管理系统(Relational DBMS),比如:Oracle,SQL Server, MySQL。 PostgreSQL

2. 键-值 存储,比如:Redis。Memcached, DynamoDB

3. 文件存储,比如:MongoDB,CouchDB,Couchbase

4. 大数据存储系统, 比如:Cassandra,HBase。Google's Bigtable

5. 基于Hadoop的数据分析系统。比如:Hive,Spark。Impala(第四类和第五类,多多少少有些交叉。)

6. 文本查询系统, 比如:Solr, Elasticsearch.

除了上面的常见类型,还有其它非常多小分支,如图形数据库,对象数据库等。这里不作为讨论的重点。 本文主要探讨第一类传统关系型数据库系统(RDBMS)。

不同类型的数据库,适用于不同的需求,他们之间有相似也有不同。

作为第一类传统关系型数据系统。与其它类型数据库最明显的差别有几点:A)支持全部SQL语句。B)支持事务(Transaction)的ACID属性。

第二类和第三类就不具备的特点A和B,第四类和第五类大多不支持A和B。即使其它类别支持A或B。也是和RDBMS所支持的A,B有非常大不同。对于A而言。其它类别数据库也仅仅是支持某些SQL的子集。而不是整个SQL标准,或者说是较老的SQL标准,比方SQL92+。

对于B而言,不是在Row级别支持全部事务的ACID属性,那些eventually
consistency什么的,都是商业宣传词汇。事实上就是no consistency。

这里并非说其它类别的数据库不好。仅仅是我们进入了一个数据库多元化的时期。不同的数据库都有自己的特点和擅长的地方,不可一概而论。比方对于Consistency来言,银行的业务就须要strong consistency,确保资金出入正确,而微博这样的应用能够舍弃一些consistency来换取系统高吞吐量。用户不是很关心是否能即使(比方时间延误小于2秒)看到朋友的微博状态。

传统关系型数据库系统系统依据应用还能够大致分为两类:OLTP(Online Transaction Processing)和OLAP(Online analytical processing)。当中OLTP处理并发,多线程管理等事务,OLAP用于大量数据分析,是BI(Business Intelligence)的一部分。第一类的关系型数据库系统大都包括了OLTP和OLAP的功能,属于通用型的数据库。下文也着重讨论OLTP类型的数据库。

传统关系型数据库性能分析及瓶颈

近些年有关传统数据库性能的分析,已经有非常多非常多。

我个人比較看好惠普HP和麻省理工大学MIT联合研究出的一片文献《OLTP Through the Looking Glass, and What We Found There》。简单的讲,他们的对当代数据库进行了解刨式地分析。得出结论:传统关系通用型数据库,仅仅有10%左右的时间是处理有效数据。剩下90%的时间都浪费在其它辅助工作上:Buffer manager,Latching,Locking。logging,Btree keys等。

上图这是他们跑TPC-C benchmark得出不同数据库部分的性能图标,左側为指令的百分比。右側为CPU cycle(即CPU运行时间)的百分比。白色部分为真正实用的数据处理,剩下的都是传统数据库不可或缺的部分,可是消耗了大量的资源。由上图所看到的,缓存管理和锁,门闩和日志都是传统关系型数据库实际较大的开销。

传统数据库的性能缺陷一直没有提到大家的日程上,主要还是由于在过去数据量太小的缘故。随着近10年因特网的发展,尤其是近5年移动端应用爆炸式的涌现,数据量也在井喷式的增长。

在当代,谁能处理好大数据,谁能挖掘Big data的商业价值。谁就能赚到钱。

不少科技公司的竞争,就是数据处理能力的竞争。

这也是为什么近10年涌现出非常多NoSQL的数据库和NewSQL的数据库。NoSQL发展的早些,现有非常多知名的系统,比如Google的Big Table,Amazon的DynamoDB,Apache的HBase,Cassandra等。NewSQL系统出现的晚于NoSQL大概5,6年吧。如今流行的有VoltDB,NuoDB。Clustrix等。

他们的共同点都是解决大数据的处理性能问题,不同点是NewSQL系统,旨在解决NoSQL不支持标准SQL语言和事务Transaction不全支持ACID属性的特点。

换句话说,NewSQL的功能要比NoSQL更加全面,更加兼容传统数据。

好多人想问,为什么市面上流行的数据库居然如此差。设计成这个样子?难道大家都错了吗?事实上这个问题非常easy,传统数据库开发得非常早,最早可追述到上世纪七八十年代。距今至少也有30个年头了。这样的数据库系统实际架构和模式,是由当时总体计算机硬件水平和理论水平而决定的。

近些年硬件发展速度相当迅猛,不管是从Disk/RAM的大小到价格,还是CPU的性能和多核(Multi-core)技术等,比起30年前,都有飞跃式的发展。虽然摩尔定律这两年半导体技术发展的增长速度已经放缓,可是还在不断进步。再者就是由于。30年前数据库的应用非常单一非常easy,经过这么多年的发展,我们的实际的数据处理需求也在不断多样化。传统数据库也随之不断地添加不同的功能,使之越来越庞大。

新型OLTP数据库的架构


为了去除传统数据库的性能瓶颈。MIT大学的研究者,依据当前的硬件水平,全然又一次设计了数据库,而不在之前的传统数据库上进行微笑更改。

当代新型数据库也来越注重分布式scale out。而传统数据库则还在提高单台机器的处理能力scale up。对于普通用户来讲,不可能像大型企业一样资金雄厚。购买价格昂贵的大型机和数据库软件。

假设要对数据进行备份,做到High Avaliability的话,就须要至少再购买并执行一个副本。

新型OLTP数据库解决方式

数据库系统的更改目的 新型OLTP数据库技术
去除logging开销 使用新型logging
去除locking,latching等开销 数据分区 + 单线程运行
去除buffer manager开销 使用内存,代替磁盘读写

依据相关学者研究的结果看。去除这些重大开销后。OLTP关系型数据库Transaction的吞吐量提高了至少20倍

传统数据库没落,OLTP新型数据库发展火热的更多相关文章

  1. 数据管理技术发展,数据库应用发展史,数据库分类,MySQL

    计算机数据管理技术发展 1. 自由管理阶段 用户以文件形式将数据组织起来,并附属在各自的应用程序下.    1.数据不保存     当时计算机主要用于科学计算,一般不需要将数据长期保存,只是计算某一课 ...

  2. [转]初试visual studio2012的新型数据库LocalDB 及 在visual studio2012中如何使用localDB具体讲解

    本文转自:http://www.cnblogs.com/zhangran/archive/2012/08/26/2657864.html 初试visual studio2012的新型数据库LocalD ...

  3. 首先给大家介绍一下数据库project师,数据库project师(Database Engineer),是从事管理和维护数据库管理系统(DBMS)

    摘要 MySQL的最初的核心思想,主要是开源.简便易用.其开发可追溯至1985年,而第一个内部发行版本号诞生,已经是1995年. 到1998年,MySQL已经能够支持10中操作系统了.当中就包含win ...

  4. NoSQL:从关系型数据库到非关系型数据库

    关系型数据库 所谓关系型数据库,,就是指采用了关系模型来组织数据的数据库. 什么是关系模型,简单说,关系模型就是二维表格模型,而一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织. 关系模 ...

  5. Hbase与Oracle比较(列式数据库与行式数据库)

    Hbase与Oracle比较(列式数据库与行式数据库) 1 主要区别 Hbase适合大量插入同时又有读的情况 Hbase的瓶颈是硬盘传输速度,Oracle的瓶颈是硬盘寻道时间.   Hbase本质上只 ...

  6. 洞见数据库前沿 阿里云数据库最强阵容 DTCC 2019 八大亮点抢先看

    摘要: 作为DTCC的老朋友和全球领先的云计算厂商,阿里云数据库团队受邀参加本次技术盛会,不仅将派出重量级嘉宾阵容,还会为广大数据库业内人士和行业用户奉上8场精彩议题.下面小编就为大家提前梳理了8大亮 ...

  7. 【Redis】(1)-- 关系型数据库与非关系型数据库

    关系型数据库与非关系型数据库 2019-07-02  16:34:48  by冲冲 1. 关系型数据库 1.1 概念 关系型数据库,是指采用了关系模型来组织数据的数据库.关系模型指的就是二维表格模型, ...

  8. 关系型数据库和非关系型数据库区别、oracle与mysql的区别

    一.关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库.    关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐 ...

  9. 阿里云重磅发布DMS数据库实验室 免费体验数据库引擎

    2月27日,阿里云数据管理DMS发布年度巨献——数据库实验室,用户可在该实验室环境下免费体验数据库引擎.以及DMS各项产品功能.数据库实验室是DMS所提供的体验空间,免费赠送数据库引擎资源. 用户只需 ...

随机推荐

  1. Unity3D中的UnitySendMessage方法的使用

    UnitySendMessage(“string”,“string”, ***),这是方法,我们至少需要传入两个参数,第一个参数为unity中的一个gameobject名称,第二个参数为这个gameo ...

  2. 精简高效CSS系列之二——浮动float

    一.浮动基础知识 假如一个页面上有3个div块,如下排列: 图1:不使用浮动 图2:向右浮动 图2说明了框1脱离了文档流向右移动,直到它的右边缘碰到包含框的右边缘为止. 图3:向左浮动 图3说明了框1 ...

  3. Windows Apache Django 配置

    所有刚刚学习Django 都会在这里配置的时候遇到问题.这里我简单秒速一个傻瓜步骤,使得大家更容易上手. 一.环境准备 1.windows 32系统 至少是 XPSP3 版本,注意:apache2.X ...

  4. 全栈project师体能备战--知识面(1--10)

    javascript 单例设计模式:         单例模式确保某个类仅仅有一个势力,并且自行实例化并向整个系统提供这个实例.如:cocos2dx中的导演类.[样例]我有6哥美丽的老婆,他们的老公都 ...

  5. QN-H618 遥控器复制再生仪(拷贝机)

    针对现在市场上日益更新的遥控器种类,本公司经过长时间的研究,推出新一代拷贝机,本产品有以下特点: 1. 众多车库门遥控分析信息被集成在一台机器内,只要一种遥控器,就可以复制众多品牌的车库遥控.免去积压 ...

  6. Make a DAC with a microcontroller's PWM timer

    http://www.edn.com/design/analog/4337128/Make-a-DAC-with-a-microcontroller-s-PWM-timer Many embedded ...

  7. JQUERY AJAX无刷新异步上传文件

    AJAX无刷新上传文件并显示 http://blog.csdn.net/gao3705512/article/details/9330637?utm_source=tuicool jQuery For ...

  8. 在Windows Phone项目中调用C语言DLL

    在Windows Phone项目中调用C语言写的DLL 最近接到一个需求,需要在WP里调用一个C语言写的DLL,并且说Android和iOS都可以,问我WP是否可以这样? 我说我调研一下,就有了下面的 ...

  9. python接口自动化1-发送get请求

    前言 requests模块,也就是老污龟,为啥叫它老污龟呢,因为这个官网上的logo就是这只污龟,接下来就是学习它了. 一.环境安装 1.用pip安装requests模块 >>pip in ...

  10. 学习node js 之微信公众帐号接口开发 准备工作之三

    app.js文件介绍,因为也是初学,以下的内容是个人的理解,有些不正确的地方请评论中指证:以注解的形式说明. //依赖组件[模块]导入 var express = require('express') ...