将 MySQL 迁移到 MariaDB 上
1、准备 MySQ雉搽妤粲L 数据库和表出于演示的目的,我们在做迁移之前在数据库中创建一个测试的 MySQL 数据库和表。如果你在 MySQL 中已经有了要迁移到 M锾攒揉敫ariaDB 的数据库,跳过此步骤。否则,按以下步骤操作。《linux就该这么学》中查阅1.在终端输入 root 密码登录到 MySQL 。$ mysql -u root -p2.创建一个数据库和表。mysql> create database test01; mysql> use test01; mysql> create table pet(name varchar(30), owner varchar(30), species varchar(20), sex char(1));3.在表中添加一些数据。mysql> insert into pet values('brandon','Jack','puddle','m'),('dixie','Danny','chihuahua','f');4.退出 MySQL 数据库.
2、备份 MySQL 数据库1.备份现有的 MySQL 数据库,使用下面的 mysqldump 命令导出现有的数据库到文件中。运行此命令之前,请确保你的 MySQL 服务器上启用了二进制日志。$ mysqldump --all-databases --user=root --password --master-data > backupdb.sql2.现在,在卸载 MySQL 之前先在系统上备份 my.cnf 文件。此步是可选的。$ sudo cp /etc/mysql/my.cnf /opt/my.cnf.bak
3、卸载 MySQL1.首先,停止 MySQL 服务,请从以下三个命令中任选一个执行$ sudo service mysql stop //RHEL6 $ sudo systemctl stop mysql //RHEL7 $ sudo /etc/init.d/mysql stop //RHEL62.使用以下命令移除 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
4、安装 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 的官方仓库.
5、安装 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 的官方仓库.
6、故障排除在运行 mysqldump 命令备份数据库时出现以下错误。mysqldump: Error: Binlogging on server not active通过使用 "--master-data",你可以在导出的输出中包含二进制日志信息,这对于数据库的复制和恢复是有用的。但是,二进制日志未在 MySQL 服务器启用。要解决这个错误,修改 my.cnf 文件,并在 [mysqld] 部分添加下面的选项。(LCTT 译注:事实上,如果你并没有启用二进制日志,那取消"--master-data"即可。)log-bin=mysql-bin保存 my.cnf 文件,并重新启动 MySQL 服务。