MYSQL与NOSQL

仅仅几年前,MySQL还是开源数据库领域公认的王者,但是随着NoSQL以82%的年复合增长率狂飙,MySQL在web应用市场正面临被NoSQL淘汰的危险。

 

技术分享

向NoSQL的迁移不但成为IT业发展趋势的一个注脚,还让人们领略了开源驱动的产业创新正如疾风骤雨般来临。

这一切与Oracle对MySQL的管理无关,实际上,Oracle对MySQL可谓尽心尽力,投入大量资源改进技术,培养社区。正如451 Research的的研究经理Matthew Aslett所言:“MySQL生态系统比过去更加健康和富有活力,Oracle对核心产品全力支持,提供大量互补产品和服务增强其竞争力。”

那么MySQL到底怎么了?Aslett在一次开源商务会议上分享了他的观点。

他认为,绝大多数因为Oracle入主而弃用MySQL的企业普遍给Oracle的MySQL管理工作“好评”,极少数给了“中评”。

事实上451 Research预测MySQL市场价值将在2015年达到6.64亿美元,年复合增长率是“健康的”40%。

技术分享

可以看到,上面这张图表中唯一“不健康”的因素就是NoSQL的快速崛起。Aslett指出,12.7%的弃用MySQL的企业直接投入了NoSQL的怀抱,但这对MySQL的安装基数影响不大。最常见的MySQL替代品实际上是PostgreSQL。但即使是PostgreSQL对MySQL的安装基数威胁也不大。

换而言之,总体上NoSQL对MySQL的安装基数并无多大威胁。

但是在web应用领域,NoSQL对MySQL形成了明显的威胁,虽然很少有人更换现有应用的支撑台数据库,但是越来越多的新web应用选择了NoSQL的道路。451 Research认为:“那些强调高可扩展性、性能和灵活性的新项目更多地采用了NoSQL数据库技术。”

早在2009年,当时的MySQL首席执行官Marten Mickos认为MySQL应当作为Sun公司的一部分被Oracle收购,因为MySQL与Oracle并没有直接的竞争关系。Mickos认为:“MySQL正在以疯狂的速度增长,但这并没有伤到Oracle。MySQL主要面向web应用。Oracle则是面向较老的企业级遗留系统。”

今天,同样的故事正在上演,NoSQL正在以疯狂的速度占领web应用市场,而MySQL则节节败退。

这个变化实在是太快了,简直不可思议。NoSQL的概念1998年问世,但是直到2009年才初露端倪,当时MySQL还是开源数据库毫无争议的王者,但是MySQL的统治地位非常不牢固,Aslett用451Research的一系列报告标题展示了这一点:

“MySQL是开源数据库世界王冠上的明珠。”

——2008年5月

“Oracle的竞争对手对Oracle收购MySQL感到无解。”

——2009年5月

“数据库市场正受到来自轻量级架构的开源数据库的冲击,这些数据库主要面向web应用。”

——2011年4月

从2009年到2011年,仅仅两年时间,NoSQL就从非主流发展成MySQL在web应用市场的终结者,这充分显示了开源对于创新的巨大驱动力。

看看那些驱动今日之IT产业的重要技术吧,根据InformationWeek的调查,CIO们普遍认为云计算和大数据是2012年最总要的两个技术:

CIO们2012年最终要的两个IT预算项目是什么?云计算和大数据!而开源软件是云计算和大数据潮流最重要的驱动力,例如Hadoop、Pig、Linux或OpenStack。

虽然开源软件已经开始占领数据中心,但开源最具统治力的领域是云计算。Red Hat的产品管理总监Bryan Che认为:

开源技术是建设云计算平台的基础。就服务器市场份额而言,在传统数据中心windows平台占据70%的市场,而Linux只有30%。但是当人们选择建设云计算平台的操作系统时,Windows和Linux的市场占有率完全颠倒过来了。

云计算的概念由来已久,但是直到开源软件将云计算的建设成本大幅降低后,云计算才得以蓬勃发展;类似的变化也发生在数据挖掘和数据仓库领域,直到Hadoop大幅降低大数据挖掘成本的同时提高了其性能,大数据才真正得以流行。

我们目前正处于“超创新”时代,开源软件的最大竞争对手不再是步履蹒跚的传统商业软件,而是另外一款开源软件。NoSQL在web应用市场对MySQL的威胁就是很好的例子,同样的情形还在出现在Hadoop领域,对于用户来说,在竞争的开源软件之间进行选择变得越来越困难,但这也意味着开源软件正在以前所未有的速度变得更好。

转载于:php100

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。