从MySQL迁移到MariaDB(CentOS)

  下面先摘录一点背景介绍,然后是我在 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. 迁移操作记录(下面的 3 的方法更好)

  这个 VPS 安装的是 CentOS,目前版本是 6.4,MySQL 版本是 5.5.31(使用了 remi 源),虚拟机的配置与此极度相似。刚开始不太了解,执行了这个比较傻的操作方式。

  A. 先配置 MARIADB 的安装源。

  目前 MariaDB 的主版本是 5.5,我的 CentOS 是 32 位的,将下面的安装源配置保存为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。

  另外,因为之前进行了卸载操作,所以原来的 MySQL 和 phpMyAdmin 的配置文件都被清除了,也需要重新配置。特别是 MySQL 的配置文件 /etc/my.cnf,因为 MariaDB 虽然创建了一个my.cnf.d 文件夹来存储自己的配置文件,但是它会首先加载 my.cnf,且原来 MySQL 的配置的 [mysqld] 那一节的内容还是有效的。

  3. 较好的升级方法

  还是在上面介绍的系统配置下,先添加 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,到时候再自然而然地迁移吧。

时间: 2024-12-02 16:20:05

从MySQL迁移到MariaDB(CentOS)的相关文章

Linux 上从 MySQL 迁移到 MariaDB 的简单步骤

Linux 上从 MySQL 迁移到 MariaDB 的简单步骤 大家好!这是一篇介绍如何在服务器或个人电脑上从MySQL迁移到MariaDB的教程.也许你会问为什么我们要将数据库管理从MySQL迁移到MariaDB.往下看我们告诉你为什么这样做. 为什么要用MariaDB来代替MySQL MariaDB是MySQL社区开发的分支,也是一个增强型的替代品.它由MySQL前开发者们带头组织的基金会开发,使用起来和MySQL完全一样.自从Oracle买下了MySQL,它就不再自由开源了,但是 Mar

Linux系统上MySQL迁移到MariaDB的【图文教程】

MariaDB来代替MySQL的原因 MariaDB使用起来和MySQL完全一样.自从Oracle买下了MySQL,它就不再自由开源了,但是 MariaDB仍然自由开源.一些如谷歌.维基.LinkedIn.Mozilla等的顶级的网站已经迁移到MariaDB了.它的优势在哪里: 向后兼容MySQL 永远开源 由MySQL缔造者的维护 更尖端的功能 更多的存储引擎 大型的网站已经转向MariaDB 现在,让我们迁移到MariaDB吧! 让我们创建一个叫linoxidedb的用于测试的示例数据库.

在 Linux 中怎样将 MySQL 迁移到 MariaDB 上

自从甲骨文收购 MySQL 后,由于甲骨文对 MySQL 的开发和维护更多倾向于闭门的立场,很多 MySQL 的开发者和用户放弃了 MySQL.在社区驱动下,促使更多人移到 MySQL 的另一个叫 MariaDB 的分支.在原有 MySQL 开发人员的带领下,MariaDB 的开发遵循开源的理念,并确保它的二进制格式与 MySQL 兼容.Linux 发行版如 Red Hat 家族(Fedora,CentOS,RHEL),Ubuntu 和 Mint,openSUSE 和 Debian 已经开始使用

维基百科正式从MySQL迁移到MariaDB数据库

近日,http://www.aliyun.com/zixun/aggregation/31877.html">全球最大的自由.免费.内容开放的网络百科全书Wikipedia正式从MySQL迁移到MariaDB数据库. 在做正式迁移前Wikipedia做了大量的准备工作,包括兼容性测试和性能测试,详情请看官方说明.此前,2012年CSDN研发频道曾报道过Wikipedia开发者Asher Feldman宣称将英文维基的一个(slave)数据库从MySQL5.1 + Facebook补丁集迁移

Linux下将数据库从MySQL迁移到MariaDB的基础操作教程_Mysql

自从2012年来,维基百科已经开始从MySQL迁移到MariaDB的过程,是维基媒体数据库架构变革的一个重大里程碑,将英文和德文版的维基百科数据库Wikidata移植到了MariaDB 5.5版本上. 在过去几年中,维基百科一直使用 Facebook 的 MySQL 5.1 衍生版本 作为我们的产品数据库,构建版本号是r3753.我们很高兴该产品的性能表现,Facebook 有着全世界最棒的数据库工程师,他们为 MySQL 生态系统带去了很多改进. 现在 MariaDB 的优化器的增强.Perc

从MySQL 5.5迁移到Mariadb 10.1.14所遇到的问题_Mysql

迁移计划如下: 1.备份MySQL 5.5的数据库,对指定库进行备份. 2.还原到Mariadb,然后建立复制. 3.然后就可以愿意啥时候切换就啥时候切换. 遇到的问题: 因为一般都是innodb,所以我想用xtrabackup工具备份.备份后发现还原需要依赖innodb的表空间切换. 1.表空间切换,必须要打开innodb_file_per_table.也就是说所有的表都要有独立的文件.有一些表虽然是innodb但是存在ibdata下面. 幸好可以申请维护窗口,简单粗暴的重建了. 2.从MyS

Ubuntu环境下将 Mysql 5.5 数据库迁移到 MariaDB 10 步骤

这篇文章是我们自己亲手实验过的,系统为 Ubuntu 14.04 server,Mysql 数据库为 Mysql 5.5,准备迁移到 Maria DB 10.1 版本,关于其他版本的迁移方法详细的说明你可以去官方查看,这里我只说说我所实验过的. 关于为什么迁移到 MariaDB,知道 Oralce 收购 Sun 的用户应该知道,当然这已经是几年以前的事情了,本人一直不是很喜欢oracle在MySQL上面的态度,自己要是安装数据库基本上都会使用 MariaDB.整个迁移过程基本无痛,也没什么需要特

将MySQL迁移到Microsoft SQL Server 2000 (二)

mysql|server 用于数据迁移的 MySQL 工具 MySQL 提供了几个客户端工具和实用程序,最常用的有: mysql - 一个交互式客户程序,可以对数据库发布查询并查看结果 mysqldump - 此工具可以提取 MySQL 数据库中的架构和数据,并放到一个文件中 mysqlimport - 此工具可以读取文件中的架构和数据,并放到一个 MySQL 数据库中 mysqladmin - 此工具可以执行管理任务,比如创建数据库和删除数据库 myODBC - 一个 32 位的开放式数据库连

将MySQL迁移到Microsoft SQL Server 2000 (一)

mysql|server 将MySQL迁移到Microsoft SQL Server 2000 摘要 本白皮书描述了 Microsoft SQL Server 2000 的迁移能力,并提供了帮助开发人员将 MySQL 数据库迁移到 SQL Server 2000 的特定信息. 引言 本指南解释如何利用几个内置的 SQL Server 工具和实用程序将 MySQL 迁移到 Microsoft? SQL Server? 2000.它还提供了如何修改 MySQL 应用程序,使之与 SQL Server