在Linux中怎樣將MySQL遷移到 MariaDB 上

來源:互聯網
上載者:User

標籤:linux   linux教程   linux視頻   linux資料   linux自學   

自從甲骨文收購 MySQL 後,由於甲骨文對 MySQL 的開發和維護更多傾向於閉門的立場,很多 MySQL 的開發人員和使用者放棄了 MySQL。在社區驅動下,促使更多人移到 MySQL 的另一個叫 MariaDB 的分支。在原有 MySQL 開發人員的帶領下,MariaDB 的開發遵循開源的理念,並確保它的二進位格式與 MySQL 相容。Linux 發行版如 Red Hat 家族(Fedora,CentOS,RHEL),Ubuntu 和 Mint,openSUSE 和 Debian 已經開始使用,並支援 MariaDB 作為 MySQL 的直接替換品。

如果你想要將 MySQL 中的資料庫遷移到 MariaDB 中,這篇文章就是你所期待的。幸運的是,由於他們的二進位相容性,MySQL-to-MariaDB 遷移過程是非常簡單的。如果你按照下面的步驟,將 MySQL 遷移到 MariaDB 會是無痛的。

 

準備 MySQL 資料庫和表

出於示範的目的,我們在做遷移之前在資料庫中建立一個測試的 MySQL 資料庫和表。如果你在 MySQL 中已經有了要遷移到 MariaDB 的資料庫,跳過此步驟。否則,按以下步驟操作。

在終端輸入 root 密碼登入到 MySQL 。

$ mysql -u root -p 

建立一個資料庫和表。

mysql> create database test01;

mysql> use test01;

mysql> create table pet(name varchar(30), owner varchar(30), species varchar(20), sex char(1));

在表中添加一些資料。

mysql> insert into pet values(‘brandon‘,‘Jack‘,‘puddle‘,‘m‘),(‘dixie‘,‘Danny‘,‘chihuahua‘,‘f‘); 

退出 MySQL 資料庫.

 

備份 MySQL 資料庫

下一步是備份現有的 MySQL 資料庫。使用下面的 mysqldump 命令匯出現有的資料庫到檔案中。運行此命令之前,請確保你的 MySQL 伺服器上啟用了二進位日誌。

$ mysqldump --all-databases --user=root --password --master-data > backupdb.sql 

現在,在卸載 MySQL 之前先在系統上備份 my.cnf 檔案。此步是可選的。

$ sudo cp /etc/mysql/my.cnf /opt/my.cnf.bak 

 

卸載 MySQL

首先,停止 MySQL 服務。

$ sudo service mysql stop

或者:

$ sudo systemctl stop mysql

或:

$ sudo /etc/init.d/mysql stop 

然後繼續下一步,使用以下命令移除 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。

下面例子中,我們使用 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 

 

CentOS 7

以下為 MariaDB 建立一個自訂的 yum 倉庫檔案。

$ sudo vi /etc/yum.repos.d/MariaDB.repo 

[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 的 root 使用者建立一個新密碼。設定 root 的密碼後,別忘了恢複備份的 my.cnf 檔案。

$ sudo cp /opt/my.cnf /etc/mysql/

現在啟動 MariaDB 服務。

$ sudo service mariadb start

或:

$ sudo systemctl start mariadb

或:

$ sudo /etc/init.d/mariadb start 

 

匯入 MySQL 的資料庫

最後,我們將以前置出的資料庫匯入到 MariaDB 伺服器中。

$ mysql -u root -p < backupdb.sql 

輸入你 MariaDB 的 root 密碼,資料庫匯入處理程序將開始。匯入處理程序完成後,將返回到命令提示字元下。

要檢查匯入處理程序是否完全成功,請登入到 MariaDB 伺服器,並查看一些樣本來檢查。

 

$ mysql -u root -p

MariaDB [(none)]> show databases;

MariaDB [(none)]> use test01;

MariaDB [test01]> select * from pet; 

 

結論

如你在本教程中看到的,MySQL-to-MariaDB 的遷移並不難。你應該知道,MariaDB 相比 MySQL 有很多新的功能。至於配置方面,在我的測試情況下,我只是將我舊的 MySQL 設定檔(my.cnf)作為 MariaDB 的設定檔,匯入處理程序完全沒有出現任何問題。對於設定檔,我建議你在遷移之前請仔細閱讀 MariaDB 配置選項的檔案,特別是如果你正在使用 MySQL 的特定配置。

 

故障排除

 在運行 mysqldump 命令備份資料庫時出現以下錯誤。

$ mysqldump --all-databases --user=root --password --master-data > backupdb.sql 

mysqldump: Error: Binlogging on server not active

通過使用 "--master-data",你可以在匯出的輸出中包含二進位日誌資訊,這對於資料庫的複製和恢複是有用的。但是,二進位日誌未在 MySQL 伺服器啟用。要解決這個錯誤,修改 my.cnf 檔案,並在 [mysqld] 部分添加下面的選項。(LCTT 譯註:事實上,如果你並沒有啟用二進位日誌,那取消"--master-data"即可。)

log-bin=mysql-bin

儲存 my.cnf 檔案,並重新啟動 MySQL 服務:

$ sudo service mysql restart

或者:

$ sudo systemctl restart mysql

或:

$ sudo /etc/init.d/mysql restart 

免費領取兄弟連IT教育原創linux營運工程師視頻/細說linux教程,詳情諮詢官網客服:http://www.lampbrother.net/linux/

或者勾搭Q2430675018

歡迎加入linux交流群 478068715


在Linux中怎樣將MySQL遷移到 MariaDB 上

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.