自从甲骨文收购 MySQL 后,因为甲骨文对 MySQL 的开发和维护更多倾向于闭门的立场,不少 MySQL 的开发者和用户放弃了它。在社区驱动下,促使更多人移到 MySQL 的另外一个叫 MariaDB 的分支,在原有 MySQL 开发人员的带领下,MariaDB 的开发遵循开源的理念,并确保它的二进制格式与 MySQL 兼容。众多Linux 发行版例如Red Hat等都支持 MariaDB 做为 MySQL 的直接替换品。
若是你想要将 MySQL 中的数据库迁移到 MariaDB 中,那么很是幸运,因为他们的二进制兼容性,MySQL-to-MariaDB 迁移过程是很是简单的。若是你按照下面的步骤,将 MySQL 迁移到 MariaDB 会是无痛的。mysql
准备 MySQL 数据库和表linux
出于演示的目的,咱们在作迁移以前在数据库中建立一个测试的 MySQL 数据库和表。若是你在 MySQL 中已经有了要迁移到 MariaDB 的数据库,跳过此步骤。不然,按如下步骤操做。sql
1.在终端输入 root 密码登陆到 MySQL 。数据库
$ mysql -u root -p
2.建立一个数据库和表。ubuntu
mysql> create database test01; mysql> use test01; mysql> create table pet(name varchar(30), owner varchar(30), species varchar(20), sex char(1));
3.在表中添加一些数据。centos
mysql> insert into pet values('brandon','Jack','puddle','m'),('dixie','Danny','chihuahua','f');
4.退出 MySQL 数据库.服务器
备份 MySQL 数据库工具
1.备份现有的 MySQL 数据库,使用下面的 mysqldump 命令导出现有的数据库到文件中。运行此命令以前,请确保你的 MySQL 服务器上启用了二进制日志。测试
$ mysqldump --all-databases --user=root --password --master-data > backupdb.sql
2.如今,在卸载 MySQL 以前先在系统上备份 my.cnf 文件。此步是可选的。url
$ sudo cp /etc/mysql/my.cnf /opt/my.cnf.bak
卸载 MySQL
1.首先,中止 MySQL 服务,请从如下三个命令中任选一个执行
$ sudo service mysql stop //RHEL6 $ sudo systemctl stop mysql //RHEL7 $ sudo /etc/init.d/mysql stop //RHEL6
2.使用如下命令移除 MySQL 和配置文件。
在基于 RPM 的系统上 (例如, CentOS, Fedora 或 RHEL):
$ sudo yum remove mysql* mysql-server mysql-devel mysql-libs $ sudo rm -rf /var/lib/mysql
在基于 Debian 的系统上(例如, Debian, Ubuntu 或 Mint):
$ sudo apt-get remove mysql-server mysql-client mysql-common $ sudo apt-get autoremove $ sudo apt-get autoclean $ sudo deluser mysql $ sudo rm -rf /var/lib/mysql
安装 MariaDB
在 CentOS/RHEL 7和Ubuntu(14.04或更高版本)上,最新的 MariaDB 已经包含在其官方源。在 Fedora 上,自19版本后MariaDB 已经替代了 MySQL。若是你使用的是旧版本或 LTS 类型如 Ubuntu 13.10 或更早的,你仍然能够经过添加其官方仓库来安装它,在MariaDB官网提供了一个在线工具帮助你依据你的 Linux 发行版中来添加MariaDB的官方仓库。此工具为 openSUSE, Arch Linux, Mageia, Fedora, CentOS, RedHat, Mint, Ubuntu, 和 Debian 提供了 MariaDB 的官方仓库.
1.在下面例子中,咱们使用 Ubuntu 14.04 发行版和 CentOS 7 配置 MariaDB 库。
Ubuntu 14.04
$ sudo apt-get install software-properties-common $ sudo apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xcbcb082a1bb943db $ sudo add-apt-repository 'deb http://mirror.mephi.ru/mariadb/repo/5.5/ubuntu trusty main' $ sudo apt-get update $ sudo apt-get install mariadb-server
CentOS7
$ sudo vi /etc/yum.repos.d/MariaDB.repo //建立自定义的yum源 ....................................... //如下为文件内容 [mariadb] name = MariaDB baseurl = http://yum.mariadb.org/5.5/centos7-amd64 gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB gpgcheck=1 ....................................... $ sudo yum install MariaDB-server MariaDB-client//安装MariaDB
2.安装了全部必要的软件包后,你可能会被要求为 MariaDB 的 root 用户建立一个新密码。设置 root 的密码后,别忘了恢复备份的 my.cnf 文件。
$ sudo cp /opt/my.cnf /etc/mysql/
3.如今启动 MariaDB 服务,请从如下三条命令中任选其一你能够运行的。
$ sudo service mariadb start $ sudo systemctl start mariadb $ sudo /etc/init.d/mariadb start
将Mysql迁移至MariaDB
咱们将之前导出的Mysql数据库导入到 MariaDB 服务器中。
$ mysql -u root -p < backupdb.sql
输入你 MariaDB 的 root 密码,数据库导入过程将开始。导入过程完成后,将返回到命令提示符下。
要检查导入过程是否彻底成功,请登陆到 MariaDB 服务器,并查看一些样原本检查。
$ mysql -u root -p ......................................//如下为sql命令 MariaDB [(none)]> show databases; MariaDB [(none)]> use test01; MariaDB [test01]> select * from pet;
结论
如你在本教程中看到的,MySQL-to-MariaDB 的迁移并不难。你应该知道,MariaDB 相比 MySQL 有不少新的功能。至于配置方面,在个人测试状况下,我只是将我旧的 MySQL 配置文件(my.cnf)做为 MariaDB 的配置文件,导入过程彻底没有出现任何问题。对于配置文件,我建议你在迁移以前请仔细阅读 MariaDB 配置选项的文件,特别是若是你正在使用 MySQL 的特定配置。
若是你正在运行有海量的表、包括群集或主从复制的数据库的复杂配置,看一看 Mozilla IT 和 Operations 团队的 更详细的指南 ,或者 MariaDB官方文档。
故障排除
在运行 mysqldump 命令备份数据库时出现如下错误。
mysqldump: Error: Binlogging on server not active
经过使用 "--master-data",你能够在导出的输出中包含二进制日志信息,这对于数据库的复制和恢复是有用的。可是,二进制日志未在 MySQL 服务器启用。要解决这个错误,修改 my.cnf 文件,并在 [mysqld] 部分添加下面的选项。(LCTT 译注:事实上,若是你并无启用二进制日志,那取消"--master-data"便可。)
log-bin=mysql-bin
保存 my.cnf 文件,并从新启动 MySQL 服务。
免费提供最新Linux技术教程书籍,为开源技术爱好者努力作得更多更好:http://www.linuxprobe.com/