MariaDB和MySQL全面对比:选择数据库需要考虑这几

谁在使用MySQL和MariaDB?

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

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

使用MariaDB的有RedHat、DBS、SUSEUbuntu、1&1、Ingenico等。

功能比较

有一些令人兴奋的新功能(如窗口函数、角色控制或公共表表达式(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+InnoDB)组合上进行的,因此得出的结论只与特定的组合有关。

复制

两个数据库都提供了将数据从一个服务器复制到另一个服务器的功能。它们的主要区别是大多数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之间的数百个不兼容问题。因此,我们无法通过简单的方案在这两个数据库之间进行迁移。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/85cb5172be26ece1799d30e023474a59.html