溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL的主從復(fù)制介紹及配置

發(fā)布時(shí)間:2020-07-26 07:40:15 來(lái)源:網(wǎng)絡(luò) 閱讀:9845 作者:10pcm 欄目:MySQL數(shù)據(jù)庫(kù)

1.MySQL主從復(fù)制介紹

    MySQL數(shù)據(jù)庫(kù)支持單向、雙向、鏈?zhǔn)郊?jí)聯(lián)、環(huán)狀等不同業(yè)務(wù)場(chǎng)景的復(fù)制。在復(fù)制過(guò)程中,一臺(tái)服務(wù)器充當(dāng)主服務(wù)器(Master),接收來(lái)自用戶的內(nèi)容更新,而一個(gè)或多個(gè)其他的服務(wù)器充當(dāng)從服務(wù)器(Slave),接收來(lái)自主服務(wù)器binlog文件的日志內(nèi)容,解析出SQL,重新更新到從數(shù)據(jù)庫(kù),使得主從服務(wù)器的數(shù)據(jù)達(dá)到一致。

    如果設(shè)置了鏈?zhǔn)郊?jí)聯(lián)復(fù)制,那么從服務(wù)器本身除了充當(dāng)從服務(wù)器外,也會(huì)同時(shí)充當(dāng)其下面從服務(wù)器的主服務(wù)器,鏈?zhǔn)郊?jí)聯(lián)復(fù)制類似A—>B—>C的復(fù)制形式。在這里,只介紹主—>從形式的配置方案。至于互為主從,鏈?zhǔn)郊?jí)聯(lián)的以后有機(jī)會(huì)再討論。

    MySQL的主從復(fù)制的主要場(chǎng)景有以下幾個(gè):

    1)從服務(wù)器作為主服務(wù)器的實(shí)時(shí)數(shù)據(jù)備份

    2)主從服務(wù)器實(shí)現(xiàn)讀寫(xiě)分離(主寫(xiě)從讀),從服務(wù)器實(shí)現(xiàn)負(fù)載均衡

    3)把多個(gè)從服務(wù)器根據(jù)業(yè)務(wù)重要性進(jìn)行拆分訪問(wèn)(從服務(wù)器根據(jù)業(yè)務(wù)進(jìn)行拆分)

2.MySQL主從復(fù)制原理介紹

    MySQL的主從復(fù)制是一個(gè)異步的復(fù)制過(guò)程(一般情況下感覺(jué)是實(shí)時(shí)的),數(shù)據(jù)將從一個(gè)MySQL數(shù)據(jù)庫(kù)(Master)復(fù)制到另外一個(gè)MySQL數(shù)據(jù)庫(kù)(Slave),在Master與Slave之間實(shí)現(xiàn)整個(gè)主從復(fù)制的過(guò)程是由三個(gè)線程參與完成的。其中有兩個(gè)線程(SQL線程和I/O線程)在Slave端,另外一個(gè)線程(I/O線程)在Master端。

    要實(shí)現(xiàn)MySQL的主從復(fù)制,首先必須打開(kāi)Master端的binlog記錄功能,否則就無(wú)法實(shí)現(xiàn)。因?yàn)檎麄€(gè)復(fù)制過(guò)程實(shí)際上就是Slave端從Master端獲取binlog日志,然后再在Slave上以相同的順序執(zhí)行獲取的binlog日志中所記錄的各種SQL操作。

    要打開(kāi)MySQL的binlog記錄功能,可以通過(guò)在MySQL的配置文件my.cnf中的mysqld模塊([mysqld]標(biāo)識(shí)后的參數(shù)部分)增加"log-bin"參數(shù)來(lái)實(shí)現(xiàn)。

3.配置MySQL主從復(fù)制

    本次實(shí)驗(yàn)的主從復(fù)制有單向的主從復(fù)制,一個(gè)Master和一個(gè)Slave。兩個(gè)MySQL服務(wù)器都按照之前的方法搭建好了,并且也都開(kāi)放了對(duì)應(yīng)的端口。

MySQL的主從復(fù)制介紹及配置

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

[mysqld]
server_id = 52            #不能和從數(shù)據(jù)庫(kù)的一樣
log-bin = /usr/local/mysql/data/mysql-bin

    保存退出之后重啟數(shù)據(jù)庫(kù)

/etc/init.d/mysqld restart

    (2)登陸主數(shù)據(jù)庫(kù),檢查參數(shù)的情況,看到log-bin已經(jīng)打開(kāi)。

MySQL的主從復(fù)制介紹及配置MySQL的主從復(fù)制介紹及配置

    (3)在主庫(kù)上建立用于主從復(fù)制的賬號(hào),檢查賬號(hào)建立成功。

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

MySQL的主從復(fù)制介紹及配置

    (4)主庫(kù)上鎖表,然后備份數(shù)據(jù)庫(kù)

flush table with read lock;

MySQL的主從復(fù)制介紹及配置

    鎖表后查看主庫(kù)狀態(tài),需要記錄在案,待會(huì)復(fù)制主庫(kù)就是從這個(gè)位置開(kāi)始的。

MySQL的主從復(fù)制介紹及配置

    新開(kāi)一個(gè)窗口,用mysqldump進(jìn)行數(shù)據(jù)的備份,然后傳輸?shù)綇膸?kù)上。

mkdir -p /server/backup    #創(chuàng)建保存?zhèn)浞菸募奈募A
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復(fù)制到從庫(kù)上

    備份結(jié)束后,解鎖主庫(kù),恢復(fù)讀寫(xiě)

MySQL的主從復(fù)制介紹及配置

    (5)從庫(kù)上操作,設(shè)置server-id并關(guān)閉binlog功能。

    從庫(kù)上的server-id不能和主庫(kù)的serverid一致,這里我們?cè)O(shè)置主庫(kù)的server-id為53,binlog的功能默認(rèn)關(guān)閉的。

MySQL的主從復(fù)制介紹及配置

    用vim編輯之后保存退出,然后重啟數(shù)據(jù)庫(kù)。

/etc/init.d/mysqld restart

    登陸mysql檢查這兩個(gè)參數(shù),確認(rèn)無(wú)誤

MySQL的主從復(fù)制介紹及配置

    (6)從庫(kù)上操作,恢復(fù)主庫(kù)導(dǎo)出的數(shù)據(jù)庫(kù)到從庫(kù)上

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

    (7)從庫(kù)上操作,配置復(fù)制參數(shù)。

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;

MySQL的主從復(fù)制介紹及配置

    這個(gè)操作實(shí)際上就是把用戶、密碼以及主庫(kù)的其他信息寫(xiě)入到從庫(kù)的master.info文件去

MySQL的主從復(fù)制介紹及配置

    (8)從庫(kù)上開(kāi)啟同步開(kāi)關(guān),測(cè)試主從復(fù)制配置情況

MySQL的主從復(fù)制介紹及配置

    查看slave的狀態(tài),注意查看slave的進(jìn)程狀態(tài),主庫(kù)復(fù)制的延遲秒數(shù)

MySQL的主從復(fù)制介紹及配置

MySQL的主從復(fù)制介紹及配置

    到這里,MySQL的主從配置基本完成了。下面我們?cè)谥鲙?kù)上增加一個(gè)數(shù)據(jù)庫(kù)pcm_test,看看從庫(kù)會(huì)不會(huì)一起更新。證實(shí)了。

MySQL的主從復(fù)制介紹及配置MySQL的主從復(fù)制介紹及配置



向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI