MariaDB 是一个采用 Maria 存储引擎的 MySQL 分支版本,是由原来 MySQL 的作者 Michael Widenius 创办的公司开发的免费开源的数据库服务器。Red Hat 企业发行版RHEL 7 将用 MariaDB 替代 MySQL,一旦 RHEL 完成切换,基于 RHEL 的社区版 CentOS 将会紧跟着作出改变。所以呢,使用 CentOS 系统的这个 VPS 或迟或早都是要切换到 MariaDB 的,大势所趋啊。
下面先摘录一点背景介绍,然后是我在 CentOS 6.4 上从 MySQL 5.5.31 迁移至 MariaDB 5.5.31 的操作记录。最后是我后来发现一个较好的迁移方法。
1. 背景介绍¶
MySQL是世界上最流行的开源关系数据库。2008 年,Sun 收购 MySQL。然后 2010 年,甲骨文又收购了 Sun,于是 MySQL 落入了甲骨文(Oracle)手中。Oracle 与开源社区关系的一直不太好,甚至 MySQL 也被弄成了社区版和企业版,不能免费商业使用;MySQL 企业版的新功能不公开源代码,这样让用户很不爽。MariaDB 则没有这方面的问题。与 MySQL 相比,MariaDB 的优势在于:
- 可免费商业使用(MySQL 则有社区版和企业版之分,拜 Oracle 所赐)
- Maria 存储引擎
- PBXT 存储引擎
- XtraDB 存储引擎
- FederatedX 存储引擎
- 更快的复制查询处理
- 线程池
- 运行速度更快
- 更多的扩展功能模块
- 支持 Unicode 排序
于是我决定先在虚拟机上看看如何由 MySQL 迁移到 MariaDB,虽然难以预料的是,不知道 Michael Widenius 会不会在什么时候又将 MariaDB 卖给哪家大公司。
原来 MariaDB 的设计初衷之一就是完全兼容 MySQL,包括 API 和客户端协议,使之能轻松成为 MySQL 的代替品,所以由 MySQL 迁移到 MariaDB 基本上可以称之为“升级”,就好像软件升级版本一样。MariaDB 的技术文档上是这样写的:
- 如果是相同的基础版本(如 5.5),可以直接卸载 MySQL 然后安装 MariaDB,这样就可以用了。甚至不需要备份然后还原数据库。当然,保险起见,升级前将所有的数据库都备份一下还是非常有必要的,以防万一。
- 如果 MariaDB 的主版本高,在经过上面的卸载 MySQL 再安装 MariaDB 操作之后,需要使用
mysql_upgrade
升级一下。是的,甚至连命令行都与使用 MySQL 的时候一样。 - 所有原先的客户端和连接器(PHP、Perl、Python、Java 等)都不需要做任何改变就能正常工作,因为 MariaDB 与 MySQL 使用的是相同的客户端协议,并且客户端库文件也是二进制兼容的。
2. 迁移操作记录¶
这个 VPS 安装的是 CentOS,目前版本是 6.4,MySQL 版本是 5.5.31(使用了 remi 源),虚拟机的配置与此极度相似。刚开始不太了解,执行了这个比较傻的操作方式。参考 MariaDB 官方文档:How can I upgrade from MySQL to MariaDB?
0. 先备份数据库¶
数据库包含了自己的几乎所有重要内容,不管进行的操作是否有风险,先备份总是很必要的。
可以通过 phpMyAdmin 导出数据库。
也可以直接在系统里将所有数据库文件备份一份:
cp -R /var/lib/mysql /var/lib/mysql.bak
A. 先配置 MariaDB 的安装源。¶
MariaDB 官方提供了一个自动生成安装源配置文件的工具:https://downloads.mariadb.org/mariadb/repositories/。依次选择 Linux 发行版(Distro)、版本(Release),然后选择 MariaDB 版本号(目前只有 10.0 和 5.5)即可。(注意,MariaDB 10 是开发版本。)
MariaDB YUM 安装源的位置:http://yum.mariadb.org/。打开后看到的是 MariaDB 版本列表,按照需要的版本号点击进入下一层文件夹。
然后根据自己的 Linux 发行版,如 CentOS、Fedora、rhel(Red Hat Enterprise Linux)以及系统架构如 x86(表示 32 位操作系统) 或 amd64(表示 64 位操作系统)选择对应的文件夹。
例如,目前 MariaDB 的主版本是 5.5,我的 CentOS 是第 6 版(6.4)、 32 位的,就选择文件夹 centos6-x86/ 。现在浏览器中的地址显示为 http://yum.mariadb.org/5.5/centos6-x86/,这就是下面配置文件中的 baseurl。
对于本例,将下面的安装源配置保存为 MariaDB.repo
,上传到服务器的 /etc/yum.repos.d
文件夹:
[mariadb] name = MariaDB enable=1 priority=3 baseurl = http://yum.mariadb.org/5.5/centos6-x86 gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB gpgcheck=1
其中 priority=3 是针对 YUM 的 PRIORITIES 优先级插件的。
B. 卸载原来的 mysql 及相关包。¶
# yum remove mysql*
上面用 * 来匹配删除所有 mysql 数据包(包括因包依赖而删除的别的包,如 postfix)。因为直接安装的时候会出现冲突,例如:
file /usr/share/mysql/ukrainian/errmsg.sys from install of MariaDB-server-5.5.31-1.i686 conflicts with file from package mysql-libs-5.5.32-1.el6.remi.i686
嗯,好像因为将 php-mysql 也给删除了(实际上这个不该删除的),所以 phpMyAdmin 也因为依赖关系而被删除了,我没仔细看。
所以最好不要用通配符 *,而是选择性删除几个主要的,
# yum remove mysql mysql-server mysql-libs
但是这个我没有再测试,因为后面有更好的方法。
C. 然后安装 MariaDB 及相应 PHP 扩展。¶
也是指定几个主要的安装包,剩下的让 yum 自己进行依赖关系检查。
# yum install MariaDB-server MariaDB-client php-mysql
或者不安装 MariaDB-server 而改为具有同步多主群集特性(synchronous multi-master cluster)的 MariaDB Galera Cluster:
# yum install MariaDB-Galera-server MariaDB-client galera
这里比较搞笑的是,没注意前面把 php-mysql 给卸载了,结果运行数据库之后访问 WordPress,结果遭遇下面的错误:
Your PHP installation appears to be missing the MySQL extension which is required by WordPress.
D. 完成,修补¶
不管版本是否升级了,执行一下数据库升级指令总没有坏处:
# mysql_upgrade -p
看看数据库版本是不是升级了:
# mysql -u root -p -e 'show global variables like "version";' Enter password: +---------------+----------------+ | Variable_name | Value | +---------------+----------------+ | version | 5.5.31-MariaDB | +---------------+----------------+
将 MariaDB 加入随系统自启动列表,
# chkconfig --levels 345 mysql on
嗯,以前 MySQL 的时候是 mysqld,现在是 mysql,就差了一个字母 d。
启动它,
# service mysql start
这个时候服务器上的网站应该已经可以正常工作了,访问数据库没有问题。
如果有必要,安装完 MariaDB 之后可以重新安装 postfix。如果发现 phpMyAdmin 提示无访问权限了,那就是被卸载了,需要重新安装和配置 phpMyAdmin。phpMyAdmin 之所以也会被删除,是因为之前安装的是针对 MySQL 的,不兼容 MariaDB,所以需要重新安装。
E. 配置文件¶
因为之前进行了卸载操作,所以原来的 phpMyAdmin 的配置文件都被清除了,需要重新配置。
而对于 MySQL 的配置文件 /etc/my.cnf
,因为 MariaDB 虽然创建了一个 my.cnf.d
文件夹来存储自己的配置文件,但是它会首先加载 my.cnf
,且原来 MySQL 的配置对 MariaDB 而言还是有效的。考虑到维护方便,可以将自定义配置放到那个 my.cnf.d
文件夹中而不去动 my.cnf
文件。
但是也有些例外:
-
- MariaDB 默认使用 Aria 存储引擎存储内部临时文件,而不是 MySQL 默认使用的 MyISAM。如果你有很多临时文件,最好增加参数
aria-pagecache-buffer-size
并设置为与key-buffer-size
相同的数值。 - 如果没有使用 MyISAM,则可以将
key-buffer-size
设置为一个极小的值,如 64K。 - 根据官方的优化说明,应该将 Query Cache 禁用:
query_cache_type = OFF
和query_cache_size = 0
。
- MariaDB 默认使用 Aria 存储引擎存储内部临时文件,而不是 MySQL 默认使用的 MyISAM。如果你有很多临时文件,最好增加参数
3. 较好的升级方法¶
2013.09.30
这个方法不行了,具体不知道为什么,还是按照上面的方法一步步来吧。
还是在上面介绍的系统配置下,先添加 MariaDB 安装源,然后直接执行系统升级,
# yum update --skip-broken
MariaDB 相关安装包会被安装,不需要的 MySQL 包将被卸载,并且升级之后不需要对系统进行修补了。看看输出的前面一部分:
============================================================================================================== Package Arch Version Repository Size ============================================================================================================== Installing: MariaDB-Galera-server i686 5.5.29-1 mariadb 19 M replacing mysql.i686 5.5.21-1.el6.remi replacing mysql-server.i686 5.5.21-1.el6.remi MariaDB-server i686 5.5.31-1 mariadb 32 M replacing mysql-server.i686 5.5.21-1.el6.remi MariaDB-shared i686 5.5.31-1 mariadb 1.0 M replacing mysql-libs.i686 5.5.21-1.el6.remi kernel i686 2.6.32-358.11.1.el6 updates 24 M libjpeg-turbo i686 1.2.1-1.el6 base 176 k replacing libjpeg.i686 6b-46.el6 Updating: .........
到这里才感觉到 MariaDB 的设计思想那个无缝替代 MySQL 不是噱头,而是实实在在的技术。于是我也就不急着给 VPS 升级到 MariaDB 了,反正过不了多久 CentOS 就会采用 MariaDB,到时候再自然而然地迁移吧。
2020.06.15
增加关于禁用 Query Cache 的说明。©
本文发表于水景一页。永久链接:<http://cnzhx.net/blog/mysql-migrate-to-mariadb/>。转载请保留此信息及相应链接。
MariaDB 博客报告了 MySQL 手册页最近发生的一个小变化:甲骨文悄悄移除了GPL授权声明。
它在Pastebin上公布了 MySQL 5.5.30和MySQL 5.5.31存在明显差异的手册页授权声明:前者声明该文档是自由软件,可以在GNU GPLv2下重新发行或修改;而后者声明软件和相关文档受知识产权法保护。(via Solidot)
不过,随后 Oracle 声明这是个 bug,并且会尽快修正。
估计是想要用授权来阻止人们转移到MariaDB,后来被发现了,大家都不更新了,就说是bug,哈哈。
呵呵,发现大家反应太激烈了,出乎他们意料,于是赶紧补救
您好 请问mysql 迁移到到mariadb需要备份数据库么
欢迎光临!备份数据库应该作为一个常规操作,因为任何小的失误都会导致严重后果,所以当然要备份了。即使不出问题,备份也算是买个保险啊。
yum update –skip-broken
不能无缝升级啊…会提示mysql和mariadb-server冲突…
是的,我也搞不懂为什么现在不行了。但仅仅是不能自动执行升级,像文章前面介绍的通过手动卸载 MySQL 相关的软件包,然后再安装 MariaDB 相关包,还是没有问题的。
引用通告: MariaDB 10 发布,据说比 MySQL 快很多倍 | 水景一页
装LNMP时候看到问是否要安装mariadb搜到你的文章,看来不用着急用mariadb,今后更新centos也会更新,谢谢了!
是啊,对我们来说这种性能提升——如果有实质的提升的话——意义不大。
我考虑迁移到mariadb中,希望社区都往mariadb迁移,这样有社区做后盾,大家更放心。
觉得个人用户还是等到发行版升级后被动升级比较方便。
我们现在是一个新项目,正在构架中,所以在考虑是否使用。
做项目可能还要考虑可能的迁移成本,谨慎些好啊。个人感觉MariaDB社区已经很不错了,特别是有Linux发行版的支持后发展会更快。
引用通告: CentOS 7 / RHEL 7 上安装 LAMP + phpMyAdmin | 水景一页
感觉现在 2015年 了 ,mysql还没出啥问题。
出问题应该还不至于吧 :D