详谈MySQL和MariaDB区别与性能全面对比_mariadb

来源:脚本之家  责任编辑:小易  

MariaDB数据库管理系统?MySQL?支?主要由?源社区?维护?采用GPL授权许?发?支?原?甲骨文公司收购?MySQL?MySQL闭源?潜?风险?社区采用?支?式?避?风险?MariaDB?目?完全兼容MySQL?包括API?命令行?使?能轻松?MySQL?代替品?存储引擎?面?使用XtraDB(英语:XtraDB)?代替MySQL?InnoDB?MariaDB由MySQL?创始?Michael Widenius(英语:Michael Widenius)主导?发?早前曾?10亿美元?价格?自?创建?公司MySQL AB卖给?SUN?随着SUN?甲骨文收购?MySQL?所?权?落入Oracle?手?MariaDB名称?自Michael Widenius?Maria?名字?MySQL[1]?关系型数据库管理系统?由瑞典MySQL AB公司?发?目前属于Oracle公司?MySQL?流行?关系型数据库管理系统?WEB应用?面MySQL?RDBMS(Relational Database Management System:关系数据库管理系统)应用软件?MySQL?种关联数据库管理系统?关联数据库?数据保存?同?表?所?数据放?仓库内?增加?速度并提高?灵?性?MySQL所使用?SQL语言?用于访问数据库?用标准化语言?MySQL软件采用?双授权政策(本词条?授权政策?社区版?商业版?由于其体积?速度快、总体拥?本低?尤其?放源码?特点?般?型网站?发都选择MySQL作?网站数据库?由于其社区版?性能卓越?搭配PHP???Apache???组?良?发环境?www.zgxue.com防采集请勿采集本网。

MariaDB数据库介绍

MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可。开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险。

MariaDB官方的解释是:完全兼容MySQL。Oracle收购的MySQL,Oracle DB和MySQL就像俩儿子,一个亲生的,一个领养的。基本差不多,不过mariadb可能会有新引擎

MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。

ariaDB为可替代MySQL的增强版本,但在已安装了MySQL的情况下同时也能安装MariaDB.(这是有意义的,例如你想从一个数据库/应用迁移到另一个数据库/应用中.) 以下是在已安装MySQL的情况下,安装MariaDB的主要

MariaDB由MySQL的创始人麦克尔·维德纽斯主导开发,他早前曾以10亿美元的价格,将自己创建的公司MySQL卖给了SUN,此后,随着SUN被甲骨文收购,MySQL的所有权也落入Oracle的手中。

MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。在存储引擎方面,使用XtraDB(英语:XtraDB)来代替MySQL的InnoDB。MariaDB由MySQL的创始人Michael Widenius(英语:

MariaDB名称来自麦克尔·维德纽斯的女儿玛丽亚(英语:Maria)的名字。

MariaDB是MySQL源代码的一个分支,在意识到Oracle会对MySQL许可做什么后分离了出来(MySQL先后被Sun、Oracle收购)。除了作为一个Mysql的“向下替代品”,网页链接MariaDB包括的一些新特性使它

MariaDB直到5.5版本,均依照MySQL的版本。因此,使用MariaDB5.5的人会从MySQL5.5中了解到MariaDB的所有功能。从2012年11月12日起发布的10.0.0版开始,不再依照MySQL的版号。10.0.x版以5.5版为基础,加上移植自MySQL 5.6版的功能和自行开发的新功能。

所以我们在比较同样功能的MySQL 和MariaDB的版本,同时在完成设计和QA方面的审核后,一个很明显的结论是MariaDB会是一个更好的产品。在大多数情况下,在选择MariaDB的时候,人们会更多的考虑到功能方面的

在存储引擎方面,10.0.9版起使用XtraDB(名称代号为Aria)来代替MySQL的InnoDB。

MariaDB的API和协议兼容MySQL,另外又添加了一些功能,以支持本地的非阻塞操作和进度报告。

这意味着,所有使用MySQL的连接器、程序库和应用程序也将可以在MariaDB下工作。

在此基础上,由于担心甲骨文MySQL的一个更加封闭的软件项目,Fedora的计划在Fedora 19中的以MariaDB取代MySQL

MariaDB和MySQL全面对比

谁在使用MySQL和MariaDB?

MySQL和MariaDB都发布了各自的用户名单。

使用MySQL的有Facebook、Github、YouTube、Twitter、PayPal、诺基亚、Spotify、Netflix等。

使用MariaDB的有Redhat、DBS、Suse、Ubuntu、1&1、Ingenico等。

MariaDB和MySQL功能比较

有一些令人兴奋的新功能(如窗口函数、角色控制或公共表表达式(CTE))可能值得一提,但本文只是为了比较两个数据库,所以我们在这里只讨论其中一方专门提供的功能,以便更好地帮助读者选择合适自己的数据库。

让我们来看一下只有其中一个数据库专门提供的功能:

1. JSON数据类型

从5.7版本开始,MySQL支持由RFC 7159定义的原生JSON数据类型,可以高效地访问JSON文档中的数据。

MariaDB没有提供这一增强功能,认为JSON数据类型不是SQL标准的一部分。但为了支持从MySQL复制数据,MariaDB为JSON定义了一个别名,实际上就是一个LONGTEXT列。MariaDB声称两者之间没有显著的性能差异,但他们并没有提供基准测试数据来支持这个说法。

值得注意的是,MySQL和MariaDB都提供了一些JSON相关函数,用于更方便地访问、解析和检索JSON数据。

2. 默认身份认证

在MySQL 8.0中,默认的身份认证插件是caching_sha2_password,而不是mysql_native_password。这一增强通过使用SHA-256算法提高了安全性。

3. MySQL Shell

MySQL Shell是MySQL的高级命令行客户端和代码编辑器。除了SQL之外,MySQL Shell还提供了JavaScript和Python脚本功能。不过用户不能使用mysqlsh访问MariaDB服务器,因为MariaDB不支持MySQL X协议。

4. 加密

MySQL对重做/撤消日志进行了加密(可配),但不加密临时表空间或二进制日志。相反,MariaDB支持二进制日志和临时表加密。

5. 密钥管理

MariaDB提供开箱即用的AWS密钥管理插件。MySQL也提供了一些用于密钥管理的插件,但它们仅在企业版中可用。

6. sys模式

MySQL 8.0提供了sys模式,这是一组对象,可帮助数据库管理员和软件工程师更好地理解通过Performance模式收集的数据。sys模式对象可用于优化和诊断,不过MariaDB没有提供这个增强功能。

7. validate_password插件

validate_password插件主要用于测试密码并提高安全性。MySQL默认启用了这个插件,而MariaDB则不启用。

8. 超级只读

MySQL通过提供超级​​只读(super read-only)模式来增强read_only功能。如果启用了read_only,服务器只允许具有SUPER权限的用户执行客户端更新。如果同时启用了super_read_only,那么服务器将禁止具有SUPER权限的用户执行客户端更新。

9. 不可见列

这个功能在MariaDB上可用,MySQL不支持该功能。这个功能允许创建未在SELECT *语句中出现的列,而在进行插入时,如果它们的名字没有出现在INSERT语句中,就不需要为这些列提供值。

10. 线程池

MariaDB支持连接线程池,这对于短查询和CPU密集型的工作负载(OLTP)来说非常有用。在MySQL的社区版本中,线程数是固定的,因而限制了这种灵活性。MySQL计划在企业版中增加线程池功能。

MySQL和MariaDB性能

近年来,出现了很多关于MySQL和MariaDB引擎性能的基准测试。我们不认为“MySQL或MariaDB哪个更快”这个问题会有一个最终的答案,它在很大程度上取决于具体的使用场景、查询、用户和连接数量等因素。

不过,如果你确实想知道,下面列出了我们发现的一些最新的基准测试结果。请注意,这些测试都是在一组特定的数据库+引擎(例如MySQL+InnoDB)组合上进行的,因此得出的结论只与特定的组合有关。

MySQL 8.0(InnoDB)和MariaDB 10.3.7(MyRocks)基准测试对比:

https://minervadb.com/index.php/2018/06/01/benchmarking-innodb-and-myrocks-performance-using-sysbench/

MariaDB 10.1和MySQL 5.7在商用硬件上的性能对比:

https://mariadb.org/maria-10-1-mysql-5-7-commodity-hardware/

MySQL 8.0和MariaDB 10.3.5性能对比及UTF8的影响:

http://dimitrik.free.fr/blog/archives/2018/04/mysql-performance-80-and-utf8-impact.html

复制功能

两个数据库都提供了将数据从一个服务器复制到另一个服务器的功能。它们的主要区别是大多数MariaDB版本允许你从MySQL复制数据,这意味着你可以轻松地将MySQL迁移到MariaDB。但反过来却没有那么容易,因为大多数MySQL版本都不允许从MariaDB复制数据。

此外,值得注意的是,MySQL GTID不同于MariaDB GTID,所以将数据从MySQL复制到MariaDB后,GTID数据将相应地做出调整。

以下是这两个数据库在复制配置方面的一些差别:

MySQL的默认二进制日志格式是基于行的,而在MariaDB中,默认的二进制日志格式是混合式的。

log_bin_compress——这个配置决定了是否可以压缩二进制日志。这个增强功能是MariaDB独有的,因此MySQL不支持。

MySQL和MariaDB之间的不兼容性

MariaDB的文档中列出了MySQL和MariaDB之间的数百个不兼容问题。因此,我们无法通过简单的方案在这两个数据库之间进行迁移。

大多数数据库管理员都希望MariaDB只是作为MySQL的一个branch,这样就可以轻松地在两者之间进行迁移。但从最新发布的几个版本来看,这种想法是不现实的。MariaDB实际上是MySQL的一个fork,这意味着在它们之间进行迁移需要考虑很多东西。

MySQL和MariaDB存储引擎

MariaDB比MySQL支持更多的存储引擎类型。但话说回来,数据库可以支持多少个存储引擎并不重要,重要的是哪个数据库可以支持适合你需求的存储引擎。

MariaDB支持的存储引擎包括:

XtraDB、InnoDB、MariaDB ColumnStore、Aria、Archive、Blackhole、Cassandra Storage Engine、Connect、CSV、FederatedX、Memory、Merge、Mroonga、MyISAM、MyRocks、QQGraph、Sequence Storage Engine、SphinxSE、Spider、TokuDB

MySQL支持的存储引擎包括:

InnoDB、MyISAM、Memory、CSV、Archive、Blackhole、Merge、Federated、Example

在Linux上安装

当你在某些Linux发行版上安装MySQL时,最后可能安装的是MariaDB,因为它是很多(不是全部)Linux发行版的默认设置。

Red Hat Enterprise/CentOS/Fedora/Debian发行版默认会安装MariaDB,而其他发行版(如Ubuntu)默认安装MySQL。

云平台上的可用性

MariaDB可作为运行在Amazon Web Services(AWS)、微软Azure和Rackspace Cloud上的服务。

MySQL在上面提到的三个平台上也是可用的,同时还可以作为托管服务在谷歌云服务平台上运行。

因此,如果你正在使用谷歌云平台,并希望云提供商为你管理服务,那么可以考虑使用MySQL,除非你希望自己安装和管理MariaDB实例。

MySQL和MariaDB许可

MariaDB采用了GPL v2许可,而MySQL提供了两个许可选项——GPL v2(用于社区版)和企业许可。

MySQL的两个许可之间的主要区别在于可用的功能和支持服务。用户可以使用MariaDB的所有功能,但对于MySQL来说并非如此。MySQL的社区版不包含线程池等功能,而这些功能会对数据库和查询性能产生重大影响。

发布频率和更新

通常,MariaDB的发布频率比MySQL更频繁。太高的发布频率既有利也有弊。从好的方面来说,用户可以更及时地收到功能和错误修复。从不好的方面来说,为了让MariaDB保持最新的状态,需要更多的工作量。

技术支持

MySQL的支持团队(包括MySQL开发人员和支持工程师)为客户提供全天候服务。甲骨文提供了多种支持选项,包括扩展支持、持续支持和高级支持,具体取决于客户的要求。MariaDB支持团队的支持工程师包括了MariaDB和MySQL数据库专家(因为很多功能最初是由MySQL团队开发的),他们为生产系统提供全天候的企业级支持。

正在进行中的开发

MySQL的开发者主要是甲骨文的MySQL团队,而MariaDB开发通过公开投票和邮件列表讨论的方式进行。此外,任何人都可以向MariaDB提交补丁,MariaDB开发团队会考虑将这些补丁添加到主代码库中。因此,从某种程度上说,MariaDB是由社区开发的,而MySQL主要由甲骨文开发。

结论

好吧,我们无法为你做出决定。我们能做的就是有针对性地问你一些问题,然后你自己做出决定: 你是否分别基于这两个数据库对你的产品性能做过测试?哪一个表现更好,为什么? 你是否打算使用其中一个数据库专门提供的功能? 你是否打算使用其中一个数据库专门提供的数据库引擎? 能够对数据库的开发过程产生影响对你来说有多重要?能够参与下一个功能变更投票对你来说有多重要? 你是要为企业版本付费还是使用社区版?社区版的功能是否能够满足你的需求? 你的操作系统是否默认支持你所选的数据库?要部署它需不需要很多工作量? 你使用的是哪个云提供商?他们是否提供托管服务,其中包括你选择的数据库? 你是否计划将来从一种数据库类型迁移到另一种数据库类型?如果是这样,你是否考虑过兼容性和复制方面的问题?

更多关于MySQL和MariaDB区别与性能全面对比请查看下面的相关链接

一,CentOS7环境下1.安装Mysql5.6.19,安装成功后,端口号:3306[root@centOS7]#mysql-uroot-h127.0.0.1-P3306-pmysql>select version();version()|5.6.19|1 row in set(0.00 sec)2.安装MariaDB10.0.12,安装成功后,口端口号:3307[root@centOS7]#mysql-uroot-h127.0.0.1-P3307-pmysql>select version();version()|10.0.12-MariaDB-log|1 row in set(0.00 sec)下面是,在Mysql安装好后,安装MariaDB10.0.12的详细方法下载最新版本的二进制编译包tar.gz(目前为mariadb-10.0.12-linux-x86_64),并将它解压到你的自定义目录中.本文档假定安装目录为/opt.创建数据所在目录及符号链接,如下所示:[root@centOS7 opt]#mkdir mariadb-data[root@centOS7 opt]#ln-s mariadb-10.0.12-linux-x86_64 mariadb[root@centOS7 opt]#ls-altotal 20drwxr-xr-x.5 root root 4096 2014-09-26 07:27.dr-xr-xr-x.23 root root 4096 2014-09-26 06:38.lrwxrwxrwx.1 root root 27 2014-09-26 07:27 mariadb->mariadb-10.0.12-linux-x86_64drwxr-xr-x.13 root root 4096 2014-09-26 07:07 mariadb-10.0.12-linux-x86_64drwxr-xr-x.2 root root 4096 2014-09-26 07:26 mariadb-data创建组mariadb及用户mariadb,设置文件对应的所属权限:[root@centOS7 opt]#groupadd-system mariadb[root@centOS7 opt]#useradd-c"MariaDB Server"-d/opt/mariadb-g mariadb-system mariadb[root@centOS7 opt]#chown-R mariadb:mariadb mariadb-10.0.12-linux-x86_64/[root@centOS7 opt]#chown-R mariadb:mariadb mariadb-data/通过从support-files中拷贝my.cnf,在/opt/mariadb目录下创建新的my.cnf:[root@centOS7 opt]#cp mariadb/support-files/my-medium.cnf mariadb-data/my.cnf[root@centOS7 opt]#chown mariadb:mariadb mariadb-data/my.cnf编辑文件/opt/mariadb-data/my.cnf,增加自定义值,socket,port,user及最重要的设置:data目录和base目录.最后的设置至少是这样的:[client]port=3307socket=opt/mariadb-data/mariadb.sock[mysqld]datadir=opt/mariadb-databasedir=opt/mariadbport=3307socket=opt/mariadb-data/mariadb.sockuser=mariadb从support-files文件中拷贝init.d脚本到对应的位置:[root@centOS7 opt]#cp mariadb/support-files/mysql.server/etc/init.d/mariadb[root@centOS7 opt]#chmod+x/etc/init.d/mariadb编辑/etc/init.d/mariadb,使用 mariadb替换 mysql设置项,如下所示:Provides:mysqlProvides:mariadbbasedir=basedir=opt/mariadbdatadir=datadir=opt/mariadb-datalock_file_path="$lockdir/mysqllock_file_path="$lockdir/mariadb你需要告诉mariadb读取唯一的cnf文件.在$bindir/mysqld_safe之后加上-defaults-file=opt/mariadb-data/my.cnf.最后参数设置应该是这样的:Give extra arguments to mysqld with the my.cnf file.This scriptmay be overwritten at next upgrade.bindir/mysqld_safe-defaults-file=opt/mariadb-data/my.cnf-datadir="$datadir"-pid-file="$mysqld_pid_file_path"$other_args>/dev/null 2>&1&显式指定 my.cnf作为传入参数,来运行 mysql_install_db:[root@centOS7 opt]#cd mariadb[root@centOS7 mariadb]#scripts/mysql_install_db-defaults-file=opt/mariadb-data/my.cnf现在你可以这样启动MariaDB:[root@centOS7 opt]#etc/init.d/mariadb startStarting MySQL SUCCESS把MariaDB启动设置为系统级别启动:[root@centOS7 opt]#cd/etc/init.d[root@centOS7 init.d]#chkconfig-add mariadb[root@centOS7 init.d]#chkconfig-levels 3 mariadb on最后,测试现在有两个数据库服务实例在运行:[root@centOS7~]#mysql-e"SELECT VERSION();VERSION()|5.6.19|[root@mariadb-near-mysql~]#mysql-e"SELECT VERSION();socket=opt/mariadb-data/mariadb.sockVERSION()|10.0.12-MariaDB-log|内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • 浅谈mysql和mariadb区别(mariadb和mysql的性能比较)
  • 浅谈mysql和mariadb区别
  • 详谈mysql和mariadb区别与性能全面对比
  • 记一次mariadb数据库无法连接
  • exchange在接收连接器上启用匿名中继的方法
  • mariadb中的thread pool详细介绍和使用方法
  • mariadb 在低配 vps 上崩溃问题处理方案
  • centos 7中成功安装mariadb的方法教程
  • centos 7安装mysql5.5和安装 mariadb使用的命令
  • 浅谈mysql和mariadb区别
  • mongodb快速入门笔记(八)之mongodb的java驱动操作代码讲解
  • mariadb性能调优工具mytop的使用详解
  • MariaDB与MySQL两个数据库怎么样同时安装使用
  • mariadb是怎么产生 的 跟mysql有啥区别
  • 是用mysql还是mariadb
  • 如何从MySQL迁移到MariaDB
  • MariaDB和MySQL差别大吗
  • window mysql和mariadb可以同时安装吗
  • mariadb和mysql哪个好
  • mariadb的命令和mysql的命令一样吗?
  • mariadb 10 和 mysql 命令一样吗
  • 安装了mariadb还用安装mysql吗
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mariadb浅谈mysql和mariadb区别(mariadb和mysql的性能比较)浅谈mysql和mariadb区别详谈mysql和mariadb区别与性能全面对比记一次mariadb数据库无法连接exchange在接收连接器上启用匿名中继的方法mariadb中的thread pool详细介绍和使用方法mariadb 在低配 vps 上崩溃问题处理方案centos 7中成功安装mariadb的方法教程centos 7安装mysql5.5和安装 mariadb使用的命令浅谈mysql和mariadb区别mongodb快速入门笔记(八)之mongodb的java驱动操作代码讲解mariadb性能调优工具mytop的使用详解浅谈mysql和mariadb区别centos 7安装mysql5.5和安装 marcentos7 下mysql重新启动mariadbmariadb中1045权限错误导致拒绝用mac中mariadb数据库的安装步骤mysql分支选择参考:percona还是详解centos 使用yum安装mariadbmariadb的主从复制、主主复制、半记一次mariadb数据库无法连接centos安装和设置mariadb的教程mysql分支选择参考:percona还是mariadb我是如何用2个unix命令给mariadb sql提速关于mongoose连接mongodb重复访问报错的解centos中找回mariadb数据库root用户权限的mariadb中的thread pool详细介绍和使用方mariadb中1045权限错误导致拒绝用户访问的mariadb的主从复制、主主复制、半同步复制centos6.7系统中编译安装mariadb数据库mac中mariadb数据库的安装步骤centos7 下mysql重新启动mariadb篇
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved