日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何在Linux中將MySQL遷移到MariaDB

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

十年專注成都網(wǎng)站制作,成都定制網(wǎng)站,個人網(wǎng)站制作服務,為大家分享網(wǎng)站制作知識、方案,網(wǎng)站設計流程、步驟,成功服務上千家企業(yè)。為您提供網(wǎng)站建設,網(wǎng)站制作,網(wǎng)頁設計及定制高端網(wǎng)站建設服務,專注于成都定制網(wǎng)站,高端網(wǎng)頁制作,對成都建筑動畫等多個方面,擁有多年的網(wǎng)站運維經(jīng)驗。

如果你想要將 MySQL 中的數(shù)據(jù)庫遷移到 MariaDB 中,這篇文章就是你所期待的。幸運的是,由于他們的二進制兼容性,如果你參照下面的步驟,MySQL遷移到 MariaDB 的過程將是非常簡單的。

準備 MySQL 數(shù)據(jù)庫和表

出于演示的目的,我們在做遷移之前在數(shù)據(jù)庫中創(chuàng)建一個測試的 MySQL 數(shù)據(jù)庫和表。如果你在 MySQL 中已經(jīng)有了要遷移到 MariaDB 的數(shù)據(jù)庫,跳過此步驟。否則,按以下步驟操作。

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

 
 
 
 
  1. $ mysql -u root -p

創(chuàng)建一個數(shù)據(jù)庫和表。

 
 
 
 
  1. mysql> create database test01;
  2. mysql> use test01;
  3. mysql> create table pet(name varchar(30), owner varchar(30), species varchar(20), sex char(1));

在表中添加一些數(shù)據(jù)。

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

退出 MySQL 數(shù)據(jù)庫。

備份 MySQL 數(shù)據(jù)庫

下一步是備份現(xiàn)有的 MySQL 數(shù)據(jù)庫。使用下面的 mysqldump 命令導出現(xiàn)有的數(shù)據(jù)庫到文件中。運行此命令之前,請確保你的 MySQL 服務器上啟用了二進制日志。如果你不知道如何啟用二進制日志,請參閱結(jié)尾的教程說明。

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

現(xiàn)在,在卸載 MySQL 之前先在系統(tǒng)上備份 my.cnf 文件。此步是可選的。

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

卸載 MySQL

首先,停止 MySQL 服務。

 
 
 
 
  1. $ sudo service mysql stop

或者:

 
 
 
 
  1. $ sudo systemctl stop mysql

或:

 
 
 
 
  1. $ sudo /etc/init.d/mysql stop

然后繼續(xù)下一步,使用以下命令移除 MySQL 和配置文件。

在基于 RPM 的系統(tǒng)上 (例如 CentOS,F(xiàn)edora 或 RHEL):

 
 
 
 
  1. $ sudo yum remove mysql* mysql-server mysql-devel mysql-libs
  2. $ sudo rm -rf /var/lib/mysql

在基于 Debian 的系統(tǒng)上(例如Debian,Ubuntu或 Mint):

 
 
 
 
  1. $ sudo apt-get remove mysql-server mysql-client mysql-common
  2. $ sudo apt-get autoremove
  3. $ sudo apt-get autoclean
  4. $ sudo deluser mysql
  5. $ sudo rm -rf /var/lib/mysql

安裝 MariaDB

在 CentOS/RHEL 7和Ubuntu(14.04或更高版本)上,***的 MariaDB 已經(jīng)包含在其官方源。在 Fedora 上,自19 版本后 MariaDB 已經(jīng)替代了 MySQL。如果你使用的是舊版本或 LTS 類型如 Ubuntu 13.10 或更早的,你仍然可以通過添加其官方倉庫來安裝 MariaDB。

MariaDB 網(wǎng)站 提供了一個在線工具幫助你依據(jù)你的 Linux 發(fā)行版來添加 MariaDB 的官方倉庫。此工具為 openSUSE,Arch Linux,Mageia,F(xiàn)edora,CentOS,RedHat,Mint,Ubuntu 和 Debian 提供了 MariaDB 的官方倉庫。

下面例子中,我們使用 Ubuntu 14.04 發(fā)行版和 CentOS 7 配置 MariaDB 庫。

#p#

Ubuntu 14.04

 
 
 
 
  1. $ sudo apt-get install software-properties-common
  2. $ sudo apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xcbcb082a1bb943db
  3. $ sudo add-apt-repository 'deb http://mirror.mephi.ru/mariadb/repo/5.5/ubuntu trusty main'
  4. $ sudo apt-get update
  5. $ sudo apt-get install mariadb-server

CentOS 7

以下為 MariaDB 創(chuàng)建一個自定義的 yum 倉庫文件。

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

 
 
 
 
  1. [mariadb]
  2. name = MariaDB
  3. baseurl = http://yum.mariadb.org/5.5/centos7-amd64
  4. gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
  5. gpgcheck=1

 
 
 
 
  1. $ sudo yum install MariaDB-server MariaDB-client

安裝了所有必要的軟件包后,你可能會被要求為 MariaDB 的 root 用戶創(chuàng)建一個新密碼。設置 root 的密碼后,別忘了恢復備份的 my.cnf 文件。

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

現(xiàn)在啟動 MariaDB 服務。

 
 
 
 
  1. $ sudo service mariadb start

或:

 
 
 
 
  1. $ sudo systemctl start mariadb

或:

 
 
 
 
  1. $ sudo /etc/init.d/mariadb start

導入 MySQL 的數(shù)據(jù)庫

***,我們將以前導出的數(shù)據(jù)庫導入到 MariaDB 服務器中。

 
 
 
 
  1. $ mysql -u root -p < backupdb.sql

輸入你 MariaDB 的 root 密碼,數(shù)據(jù)庫導入過程將開始。導入過程完成后,將返回到命令提示符下。

要檢查導入過程是否完全成功,請登錄到 MariaDB 服務器,并查看一些樣本來檢查。

 
 
 
 
  1. $ mysql -u root -p

 
 
 
 
  1. MariaDB [(none)]> show databases;
  2. MariaDB [(none)]> use test01;
  3. MariaDB [test01]> select * from pet;

結(jié)論

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

如果你正在運行有海量的表、包括群集或主從復制的數(shù)據(jù)庫的復雜配置,看一看 Mozilla IT 和 Operations 團隊的 更詳細的指南 ,或者 官方的 MariaDB 文檔。

故障排除

在運行 mysqldump 命令備份數(shù)據(jù)庫時出現(xiàn)以下錯誤。

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

 
 
 
 
  1. mysqldump: Error: Binlogging on server not active

通過使用 "--master-data",你可以在導出的輸出中包含二進制日志信息,這對于數(shù)據(jù)庫的復制和恢復是有用的。但是,二進制日志未在 MySQL 服務器啟用。要解決這個錯誤,修改 my.cnf 文件,并在 [mysqld] 部分添加下面的選項。(LCTT 譯注:事實上,如果你并沒有啟用二進制日志,那取消"--master-data"即可。)

 
 
 
 
  1. log-bin=mysql-bin

保存 my.cnf 文件,并重新啟動 MySQL 服務:

 
 
 
 
  1. $ sudo service mysql restart

或者:

 
 
 
 
  1. $ sudo systemctl restart mysql

或:

 
 
 
 
  1. $ sudo /etc/init.d/mysql restart

分享名稱:如何在Linux中將MySQL遷移到MariaDB
網(wǎng)站地址:http://www.dlmjj.cn/article/djsjigo.html