Maison > Article > base de données > 【MariaDB】MariaDB vs MySQL
MariaDB是一个可替代MySQL的增强产品 对于MariaDB的所有实际用途, 就是为了可替代相同版本下的MYSQL (如 MySQL 5.1 对应MariaDB 5.1,MariaDB 5.2MariaDB 5.3. MySQL 5.5 对应MariaDB 5.5). 这意味着: Data及table定义文件(.frm) 是兼容的. 所有的客户端API,
对于MariaDB的所有实际用途, 就是为了可替代相同版本下的MYSQL (如 MySQL 5.1 对应 MariaDB 5.1, MariaDB 5.2 & MariaDB 5.3. MySQL 5.5 对应 MariaDB 5.5). 这意味着:
mysql-client包同样可运行在
MariaDB服务中.这说明在绝大多数情况下, 你可以卸载MySQL然后安装 MariaDB,而这个过程并不困难. (如果使用的是相同主版本MariaDB则不需要转换任何的数据文件, 例如 5.1).
每个月我们会定期合并MySQL的代码,以确保我们保持数据库的兼容性,并获取任何的Oracle新增的MySQL特性与修复的bug.
同时我们在升级版本的细节上也做了大量的工作,使得现在从MySQL 5.0升级到MariaDB 5.1 比MySQL从5.0升级到5.1要容易得多.
也就是说, MariaDB具有很多MySQL所缺少的特性,如新的选项, 拓展特性, 存储引擎及相关bug的修复. 在What is in the different MariaDB Releases页面, 你可以找到所有与MariaDB版本相关的特性.
在少数情况下,MariaDB不必与MySQL相兼容,从而使得它能提供比MySQL更多更好的信息.
当用MariaDB 5.1 替换MySQL 5.1时,你可能碰到一下列表列出的所有已知的用户级别的不兼容性.
[mariadb],配置在
my.cnf文件中.CHECKSUM TABLE
可能返回不同的结果,因为MariaDB不会像MySQL 5.1一样忽略含有NULL值的列 (未来MySQL新版将会和MariaDB一样计算校验值). 你可以在MariaDB中使用--old选项来获取'old style'的校对值. 但值得注意的是,MariaDB中的MyISAM和Aria存储引擎使用的是新式校对值, 因此如果使用--old选项的话
, CHECKSUM命令将由于按行来计算校对值而显得执行缓慢
.aria_pagecache_buffer_size
设置为1M
(默认为128M
).不兼容的内容点与上述MariaDB 5.1和MySQL 5.1之间的列表相同, 另外补充一点:
<span>添加了新的</span>SQL_MODE值
: IGNORE_BAD_TABLE_OPTIONS
. 如果没有设置为此值,使用了当前存储引擎不支持的table,field或index属性(选项)时,将会提示错误. 这种变化会在错误日志中打印关于在mysql数据库中不正确定义表的警告,可使用mysql_upgrade来修复
.总的来说, MariaDB 5.2是可替换MariaDB 5.1 及 MySQL 5.1的增强版本.
--maria-
启动选项已经被移除. --aria-可以作为新的选项来替代使用
. (MariaDB 5.2 同时支持--maria-
和 --aria-
)SHOW PROCESSLIST
用额外的列 Progress
来显示部分命令的进度. 你可以通过启动mysqld时使用 --old
标志来禁用它.INFORMATION_SCHEMA.PROCESSLIST信息
使用了三个新列来报告进度: STAGE
,MAX_STAGE
, and PROGRESS
./*M!
或 /*M!#####开头的
长注释(Long comments)会被执行.max_user_connections=0
(意味着不限制用户连接数), 那么在mysql服务运行过程中这个全局变量将无法修改. 这是因为以max_user_connections=0启动的mysqld服务
不会分配计数结构体 (该结构体为每个连接记录了互斥量). 因此稍后修改这个全局变量会导致错误的计数. 如果想在服务运行过程中能修改它,那在启动服务时将该变量设置为一个较大的值.max_user_connections
(全局变量及 GRANT
选项中) 的值为-1
来禁止用户连接到服务端. 而全局变量max_user_connections
对于拥有 SUPER
权限的用户不起作用.作为XtraDB的提供程序Percona, 5.5版本里并没有提供XtraDB早期版本的完整的特性. 因此 MariaDB 5.5也不提供.
XtraDB 5.5版本不支持以下的选项. 如果你在任一my.cnf配置文件中使用了它们, 那么在升级到5.5之前移除它们.
innodb_adaptive_flushing_method
.innodb_buffer_pool_restore_at_startup
.innodb_blocking_buffer_pool_restore
.innodb_import_table_from_xtrabackup
.innodb_rollback_segment
.innodb_corrupt_table_action
.
选项名 | 旧值 | 新值 |
---|---|---|
innodb_adaptive_checkpoint | TRUE | FALSE |
innodb_change_buffering | inserts | all |
innodb_flush_neighbor_pages | 1 | area |
以下是XtraDB5.5 / InnoDB5.5 中新添加的选项. (Listed here just to have all XtraDB information in the same place未翻译)
同样可参考 Perconas guide of how to upgrade to 5.5
如果在/etc/my.cnf
或其他位置的 my.cnf
种使用到了一下选项,应该移除它们. 在MySQL 5.1或者更新的版本里也是一样的:
skip-bdb
如果你要卸载MySQL RPM包并安装 MariaDB, 注意要在卸载时将/etc/my.cnf
重命名为/etc/my.cnf.rpmsave
.
在安装MariaDB完成后,你应该按以下步骤恢复原有的配置选项:
mv -vi /etc/my.cnf.rpmsave /etc/my.cnf
MySQL客户端API可以通过MySQL-Proxy链接到MariaDB,但MariaDB客户端API会收到关于"MySQL-Proxy does not implement"的进度报告提示. 可以通过禁用client与server之间的进度报告来实现兼容性.