超越 MySQL —— 对流行数据库进行分支(一)

2014-11-24 18:41:29 · 作者: · 浏览: 0


简介


MySQL 是历史上最受欢迎的免费开源程序之一。它是成千上万个网站的数据库骨干,并且可以将它(和 Linux )作为过去 10 年里 Internet 呈指数级增长的一个有力证明。


那么,如果 MySQL 真的这么重要,为什么还会出现越来越多的核心 MySQL 产品的高端衍生产品?这是因为 MySQL 是免费的开源应用程序,所以开发人员总是可以获得其代码,并按照自己的想法修改代码,然后再自行分发代码。在很长的一段时间里,在开发人员自己的生产环境 中,没有任何值得信任的 MySQL 分支。但是,这种情况很快就发生了改变。有几个分支引起了许多人的关注。


本文将讨论受人们关注的三个流行 MySQL 分支:Drizzle、MariaDB 和 Percona Server(包括 XtraDB 引擎)。本文将简要介绍每个分支出现的原因及其目标,以及是否可在您自己的生产环境中使用它们。在本文结束时,您应该能够回答 “对我的环境来说,这些 MySQL 分支产品是否是一个好的解决方案?” 这样的问题。



为什么要进行分支?


为什么需要对 MySQL 进行分支?这是一个非常合理的问题。成千上万的网站依赖于 MySQL,并且对许多人来说,它似乎是一个很好的解决方案。但是,通常就是这样,适合许多人并不一定适合所有 人。这促使一些开发人员想要根据自己的需要开发出更好的解决方案。还有什么能比将良好的解决方案转换为完美的解决方案更好的呢?。


下面我们将介绍这些分支寻求改变的更多细节。一些分支认为 MySQL 变得太臃肿 了,提供了许多用户永远不会感兴趣的功能,牺牲了性能的简单性。如果人们对更精简的 MySQL 4 特别满意,那么为什么还要在 MySQL 5 中添加额外的复杂性呢?对于此分支来说,更好的 MySQL 分支应该更简单、更快捷,因此提供的功能也较少,但这样会使这些功能极其迅速地发挥作用,并且牢记目标受众,在本例中,目标受众是高可用性网站。


对于其他分支来说,MySQL 并没有提供足够多的 新功能,或者是添加新功能的速度太慢了。他们可能认为 MySQL 没有跟上高可用性网站的目标市场的发展形势,这些网站运行于具有大量内存的多核处理器之上。正如熟悉 MySQL 的人所知道的那样,MySQL 提供了两种存储引擎:MyISAM 和 InnoDB。这一分支认为这两种存储引擎都没有提供他们所需的内容,因此他们创建了一种非常适合其目标的新存储引擎。


此外,一些分支的最高目标是成为 MySQL 的替代产品,在这些产品中,您可以轻松地访问它们的分支,无需更改任何代码。该分支使用与 MySQL 相同的代码和界面,因此使过渡变得非常容易。但是,另一个分支声称它与 MySQL 不兼容,需要更改代码。每个分支的成熟度各不相同,一些分支声称已经准备就绪可以投入生产,而另外一些则声称目前自己还远达不到这一最高目标。


最后,关于 MySQL 在 Oracle 下将如何发展仍不太确定。Oracle 收购了 Sun,也收购了 MySQL,现在 Oracle 控制 MySQL 产品本身,并领导开发社区开发新的成品。由于 Oracle 已经有了一个商业数据库,因此人们担心他们可能没有足够的资源来使 MySQL 保持其领先地位。因此,许多分支也是这些潜在担心所产生的结果,他们担心 MySQL 作为领先的免费开源数据库提供的功能可能太少、发布周期太慢并且支持费用更昂贵。


XtraDB


XtraDB 是一款独立的产品,但它仍被认为是 MySQL 的一个分支。XtraDB 实际上是基于 MySQL 的数据库的一个存储引擎。XtraDB 被认为是已成为 MySQL 一部分的标准 MyISAM 和 InnoDB 的一个额外存储引擎。MySQL 4 和 5 使用默认的 MyISAM 存储引擎安装每个表。InnoDB 也是一个相对较新的存储引擎选择,在建立数据库时,数据库管理员和开发人员可以基于每个表选择存储引擎类型。两个存储引擎的主要区别是:MyISAM 没有提供事务支持,而 InnoDB 提供了事务支持。其他差别是许多细微的性能差别,与 MyISAM 相比,InnoDB 提供了许多细微的性能改进,并且在处理潜在的数据丢失时提供了更高的可靠性和安全性。似乎 InnoDB 是用于未来改进的更适合的存储引擎,因此从版本 5.5 开始,MySQL 已将默认存储引擎从 MyISAM 更改为 InnoDB。


基于这些优势,InnoDB 存储引擎本身拆分出了一个分支,一个名为 XtraDB 的更新的存储引擎。这个存储引擎有多新呢?它 3 年前由 Percona 首次发布,因此它相对较新。它是专门针对在现代服务器上运行的现代高可用性网站设计的。它被设计为在具有十几个或更多核心和大内存(32 GB及更多)的服务器上运行。任何公司都可以从服务器管理公司购买这些类型的服务器,因此应将数据库设计为能够充分利用这些服务器。


XtraDB 分支有另一个目标,即成为 InnoDB 存储引擎的简单替代,这样用户就可以轻松地切换其存储引擎,无需 更改任何现有的应用程序代码。XtraDB 必须能够向后兼容 InnoDB,以提供它们想要添加的所有新功能和改进。它们实现了此目标。


XtraDB 的速度有多快?我找到的一个性能测试表明:与内置的 MySQL 5.1 InnoDB 引擎相比,它每分钟可处理 2.7 倍的事务。。速度显然是一个不可以忽略的因素,在考虑替代产品时更是如此。


Percona


与内置的 MySQL 存储引擎相比,XtraDB 提供了一些极大的改进,但它不是一款独立产品,也无法轻松放入现有 MySQL 安装。因此,如果您想使用这款新引擎,则必须使用提供它的产品。


Percona Server 就是这样一款产品,由领先的 MySQL 咨询公司 Percona 发布。Percona Server 是一款独立的数据库产品,为用户提供了换出其 MySQL 安装并换入 Percona Server 产品的能力。通过这样做,就可以利用 XtraDB 存储引擎。Percona Server 声称可以完全与 MySQL 兼容,因此从理论上讲,您无需更改软件中的任何代码。这确实是一个很大的优势,适合在您寻找快速性能改进时控制质量。因此,采用 Percona Server 的一个很好的理由是,利用 XtraDB 引擎来尽可能地减少代码更改。


此外,他们是 XtraDB 存储引擎的原作者。Percona 将此代码用作开源代码,因此您可以在其他产品中找到它,但引擎的最初创建者与编写此产品的是同一个人,所以您可以随心所欲地使用此信息。


下面是 Percona Server 的声明,该声明来自它们自己的网站:


Percona 团队的最终声明是 “Percona Server 是由 Oracle 发布的最接近官方 MySQL Enterprise 发行版的版本”,因此与其他更改了大量基本核心 MySQL 代码的分支有所区别。Percona Server 的一个缺点是他们自己管理代码,不接受外部开发人员的贡献,以这种方式确保他们对产品中所包含功能的控制。


MariaDB


另一款提供了 XtraDB 存储引擎的产品是 MariaDB 产品。它与 Percona 产品非常类似,但是提供了更多底层代码更改,试图提供比标准 MySQL 更多的性能改进。MariaDB 直接利用来自 Percona 的 XtraDB 引擎,由于它们使用的是完全相同的引擎,因此每次使用存储引擎时没有显著的差别。


此外,MariaDB 提供了 MySQL 提供的标准存储引擎,即 MyISAM 和 InnoDB。因此,实际上,可以将它视为 MySQL 的扩展集,它不仅提供