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的增强产品对于mariadb的所有实际用途, 就是为了可替代相同版本下的mysql (如 mysql 5.1 对应 mariadb 5.1, mariadb 5.2 & mariadb 5.3. mysql 5.5 对应 mariadb 5.5). 这意味着:
data及table定义文件(.frm) 是兼容的.所有的客户端api, 协议及结构是相同的.所有的文件名,二进制文件,路径,端口,socket等都理应相同.所有的mysql连接器 (如php, perl, python, java, .net, myodbc, ruby, mysql c链接器等)在mariadb环境下保持不变.你需要留意一些特殊情况,具体参考 installation issues with php5 (关于旧版php5中client库兼容性的一个bug).mysql-client包同样可运行在mariadb服务中.其客户端共享库与mysql客户端版本库兼容.这说明在绝大多数情况下, 你可以卸载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 5.1与mysql 5.1的不兼容性在少数情况下,mariadb不必与mysql相兼容,从而使得它能提供比mysql更多更好的信息.
当用mariadb 5.1 替换mysql 5.1时,你可能碰到一下列表列出的所有已知的用户级别的不兼容性.
安装包名以mariadb开头,而非mysql.timings may be different as mariadb is in many cases faster than mysql.(未理解)mysqld在mariadb相应称为[mariadb],配置在my.cnf文件中.对于一个没有被正确的编译为对应版本的二进制存储引擎库,它将不能正常使用. (这是因为mysql与mariadb的服务内核结构有所不同,类似与mysql版本间的不相同). 这应该不算什么问题,因为大多数的人并不会加载新的存储引擎,而mariadb 配置了比mysql更多的存储引擎.checksum table 可能返回不同的结果,因为mariadb不会像mysql 5.1一样忽略含有null值的列 (未来mysql新版将会和mariadb一样计算校验值). 你可以在mariadb中使用--old选项来获取'old style'的校对值. 但值得注意的是,mariadb中的myisam和aria存储引擎使用的是新式校对值, 因此如果使用--old选项的话, checksum命令将由于按行来计算校对值而显得执行缓慢.慢查询日志包含更多关于查询的信息, 当你用某个脚本来解析这些慢查询日志时可能会碰到问题.默认配置下mariadb会比mysql占用多一些内存,因为默认下开启了aria存储引擎 来控制内部临时表. 如果需要mariadb少占用内存 (牺牲部分性能), 你可以将aria_pagecache_buffer_size 设置为1m (默认为128m).如果使用了 new command options, new features of mariadb 或者new storage engines, 你将很难在 mysql和mariadb之间切换.mariadb 5.2 和mysql 5.1的不兼容性不兼容的内容点与上述mariadb 5.1和mysql 5.1之间的列表相同, 另外补充一点:
添加了新的sql_mode值: ignore_bad_table_options. 如果没有设置为此值,使用了当前存储引擎不支持的table,field或index属性(选项)时,将会提示错误. 这种变化会在错误日志中打印关于在mysql数据库中不正确定义表的警告,可使用mysql_upgrade来修复.总的来说, mariadb 5.2是可替换mariadb 5.1 及 mysql 5.1的增强版本.
mariadb 5.3 ,mysql 5.1与mariadb 5.2的不兼容性因错误的转换导致的少量错误信息会有所不同,因为mariadb提供了更多关于出错的信息记录.mariadb中的特定错误号已改为从1900开始,以避免与mysql错误有冲突.毫秒单位现使用在所有上下文中; 而在mysql中某些上下文中datetime和time类型去掉了毫秒单位.unix_timestamp(constant-date-string)在mariadb中返回6位十进制数的时间戳,而mysql返回非十进制的时间戳. 因此当你使用unix_timestamp()作为分区函数时将会引发问题.通过 floor(unix_timestamp(..)) 或将日期字符串转为日期数字可以解决这个问题,如 20080101000000.mariadb对date, datetime and timestamp等类型的值做了更多更严格的检验. 例如unix_timestamp('x')先返回的是null而不是0.旧的--maria-启动选项已经被移除. --aria-可以作为新的选项来替代使用. (mariadb 5.2 同时支持--maria- 和 --aria-)show processlist 用额外的列 progress 来显示部分命令的进度. 你可以通过启动mysqld时使用 --old标志来禁用它.information_schema.processlist信息使用了三个新列来报告进度: stage,max_stage, and progress.以/*m! 或 /*m!#####开头的长注释(long comments)会被执行.启动mysqld时如果设置了max_user_connections=0 (意味着不限制用户连接数), 那么在mysql服务运行过程中这个全局变量将无法修改. 这是因为以max_user_connections=0启动的mysqld服务不会分配计数结构体 (该结构体为每个连接记录了互斥量). 因此稍后修改这个全局变量会导致错误的计数. 如果想在服务运行过程中能修改它,那在启动服务时将该变量设置为一个较大的值.你可以设置max_user_connections (全局变量及 grant 选项中) 的值为-1 来禁止用户连接到服务端. 而全局变量max_user_connections对于拥有 super 权限的用户不起作用.指令 ignore 并不会忽略所有的错误 (例如致命错误), 而只忽略了一些较为安全的信息. mariadb 5.5 与 mariadb 5.3的不兼容性xtradb作为xtradb的提供程序percona, 5.5版本里并没有提供xtradb早期版本的完整的特性. 因此 mariadb 5.5也不提供.
xtradb5.5中丢弃的选项xtradb 5.5版本不支持以下的选项. 如果你在任一my.cnf配置文件中使用了它们, 那么在升级到5.5之前移除它们.
innodb_adaptive_checkpoint ; 替换为innodb_adaptive_flushing_method.innodb_auto_lru_dump ;替换为innodb_buffer_pool_restore_at_startup.innodb_blocking_lru_restore ; 替换为innodb_blocking_buffer_pool_restore.innodb_enable_unsafe_group_commitinnodb_expand_import ; 替换为innodb_import_table_from_xtrabackup.innodb_extra_rsegments ; 替换为innodb_rollback_segment.innodb_extra_undoslotsinnodb_fast_recoveryinnodb_flush_log_at_trx_commit_sessioninnodb_overwrite_relay_log_infoinnodb_pass_corrupt_table ; 替换为innodb_corrupt_table_action.innodb_use_purge_threadxtradb_enhancements被修改默认值的xtradb选项
选项名旧值新值
innodb_adaptive_checkpoint true false
innodb_change_buffering inserts all
innodb_flush_neighbor_pages 1 area
xtradb 5.5新添加的选项以下是xtradb5.5 / innodb5.5 中新添加的选项. (listed here just to have all xtradb information in the same place未翻译)
innodb_adaptive_flushing_methodinnodb_adaptive_hash_index_partitionsinnodb_blocking_buffer_pool_restoreinnodb_buffer_pool_instancesinnodb_buffer_pool_restore_at_startupinnodb_change_buffering_debuginnodb_corrupt_table_actioninnodb_flush_checkpoint_debuginnodb_force_load_corruptedinnodb_import_table_from_xtrabackupinnodb_large_prefixinnodb_purge_batch_sizeinnodb_purge_threadsinnodb_recovery_update_relay_loginnodb_rollback_segmentsinnodb_sys_columnsinnodb_sys_fieldsinnodb_sys_foreigninnodb_sys_foreign_colsinnodb_sys_tablestatsinnodb_use_global_flush_log_at_trx_commitinnodb_use_native_aio同样可参考 perconas guide of how to upgrade to 5.5
老而不再被支持的配置选项如果在/etc/my.cnf或其他位置的 my.cnf种使用到了一下选项,应该移除它们. 在mysql 5.1或者更新的版本里也是一样的:
skip-bdb替换mysql rpm安装包如果你要卸载mysql rpm包并安装 mariadb, 注意要在卸载时将/etc/my.cnf重命名为/etc/my.cnf.rpmsave.
在安装mariadb完成后,你应该按以下步骤恢复原有的配置选项:
mv -vi /etc/my.cnf.rpmsave /etc/my.cnf
imariadb和mysql-proxy的不兼容性mysql客户端api可以通过mysql-proxy链接到mariadb,但mariadb客户端api会收到关于mysql-proxy does not implement的进度报告提示. 可以通过禁用client与server之间的进度报告来实现兼容性.