MySQL的主從複製介紹及配置

1.MySQL主從複製介紹
mysql

    MySQL數據庫支持單向、雙向、鏈式級聯、環狀等不一樣業務場景的複製。在複製過程當中,一臺服務器充當主服務器(Master),接收來自用戶的內容更新,而一個或多個其餘的服務器充當從服務器(Slave),接收來自主服務器binlog文件的日誌內容,解析出SQL,從新更新到從數據庫,使得主從服務器的數據達到一致。
sql

    若是設置了鏈式級聯複製,那麼從服務器自己除了充當從服務器外,也會同時充當其下面從服務器的主服務器,鏈式級聯複製相似A—>B—>C的複製形式。在這裏,只介紹主—>從形式的配置方案。至於互爲主從,鏈式級聯的之後有機會再討論。
數據庫

    MySQL的主從複製的主要場景有如下幾個:
vim

    1)從服務器做爲主服務器的實時數據備份
bash

    2)主從服務器實現讀寫分離(主寫從讀),從服務器實現負載均衡
服務器

    3)把多個從服務器根據業務重要性進行拆分訪問(從服務器根據業務進行拆分)
負載均衡

2.MySQL主從複製原理介紹異步

    MySQL的主從複製是一個異步的複製過程(通常狀況下感受是實時的),數據將從一個MySQL數據庫(Master)複製到另一個MySQL數據庫(Slave),在Master與Slave之間實現整個主從複製的過程是由三個線程參與完成的。其中有兩個線程(SQL線程和I/O線程)在Slave端,另一個線程(I/O線程)在Master端。
ide

    要實現MySQL的主從複製,首先必須打開Master端的binlog記錄功能,不然就沒法實現。由於整個複製過程實際上就是Slave端從Master端獲取binlog日誌,而後再在Slave上以相同的順序執行獲取的binlog日誌中所記錄的各類SQL操做。
測試

    要打開MySQL的binlog記錄功能,能夠經過在MySQL的配置文件my.cnf中的mysqld模塊([mysqld]標識後的參數部分)增長"log-bin"參數來實現。

3.配置MySQL主從複製

    本次實驗的主從複製有單向的主從複製,一個Master和一個Slave。兩個MySQL服務器都按照以前的方法搭建好了,而且也都開放了對應的端口。

blob.png

    (1)在主庫Master的配置,用vim 打開 /etc/my.cnf文件,添加server_id和log-bin參數

[mysqld]
server_id = 52            #不能和從數據庫的同樣
log-bin = /usr/local/mysql/data/mysql-bin

    保存退出以後重啓數據庫

/etc/init.d/mysqld restart

    (2)登錄主數據庫,檢查參數的狀況,看到log-bin已經打開。

blob.pngblob.png

    (3)在主庫上創建用於主從複製的帳號,檢查帳號創建成功。

grant replication slave on *.* to 'rep'@'192.168.31.%' identified by 'pcm123456';
flush privileges;

blob.png

    (4)主庫上鎖表,而後備份數據庫

flush table with read lock;

blob.png

    鎖表後查看主庫狀態,須要記錄在案,待會複製主庫就是從這個位置開始的。

blob.png

    新開一個窗口,用mysqldump進行數據的備份,而後傳輸到從庫上。

mkdir -p /server/backup    #建立保存備份文件的文件夾
mysqldump -uroot -p 'pcm123456' --events -A -B |gzip >/server/backup/mysql_bak.$(date +%F).sql.gz  #備份並壓縮
scp /server/backup/mysql_bak.2018-04-04.sql.gz root@192.168.31.53:/root/        #用scp複製到從庫上

    備份結束後,解鎖主庫,恢復讀寫

blob.png

    (5)從庫上操做,設置server-id並關閉binlog功能。

    從庫上的server-id不能和主庫的serverid一致,這裏咱們設置主庫的server-id爲53,binlog的功能默認關閉的。

blob.png

    用vim編輯以後保存退出,而後重啓數據庫。

/etc/init.d/mysqld restart

    登錄mysql檢查這兩個參數,確認無誤

blob.png

    (6)從庫上操做,恢復主庫導出的數據庫到從庫上

mysql -uroot -p  <mysql_bak.2018-04-04.sql

    (7)從庫上操做,配置複製參數。

CHANGE MASTER TO
MASTER_HOST='192.168.31.52',
MASTER_PORT=3306,
MASTER_USER='rep',
MASTER_PASSWORD='pcm123456',
MASTER_LOG_FILE='mysql-bin.000009',
MASTER_LOG_POS=120;

blob.png

    這個操做實際上就是把用戶、密碼以及主庫的其餘信息寫入到從庫的master.info文件去

blob.png

    (8)從庫上開啓同步開關,測試主從複製配置狀況

blob.png

    查看slave的狀態,注意查看slave的進程狀態,主庫複製的延遲秒數

blob.png

blob.png

    到這裏,MySQL的主從配置基本完成了。下面咱們在主庫上增長一個數據庫pcm_test,看看從庫會不會一塊兒更新。證明了。

blob.pngblob.png

相關文章
相關標籤/搜索