中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL的主從復制介紹及配置

發布時間:2020-07-26 07:40:15 來源:網絡 閱讀:9846 作者:10pcm 欄目:MySQL數據庫

1.MySQL主從復制介紹

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

    如果設置了鏈式級聯復制,那么從服務器本身除了充當從服務器外,也會同時充當其下面從服務器的主服務器,鏈式級聯復制類似A—>B—>C的復制形式。在這里,只介紹主—>從形式的配置方案。至于互為主從,鏈式級聯的以后有機會再討論。

    MySQL的主從復制的主要場景有以下幾個:

    1)從服務器作為主服務器的實時數據備份

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

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

2.MySQL主從復制原理介紹

    MySQL的主從復制是一個異步的復制過程(一般情況下感覺是實時的),數據將從一個MySQL數據庫(Master)復制到另外一個MySQL數據庫(Slave),在Master與Slave之間實現整個主從復制的過程是由三個線程參與完成的。其中有兩個線程(SQL線程和I/O線程)在Slave端,另外一個線程(I/O線程)在Master端。

    要實現MySQL的主從復制,首先必須打開Master端的binlog記錄功能,否則就無法實現。因為整個復制過程實際上就是Slave端從Master端獲取binlog日志,然后再在Slave上以相同的順序執行獲取的binlog日志中所記錄的各種SQL操作。

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

3.配置MySQL主從復制

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

MySQL的主從復制介紹及配置

    (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已經打開。

MySQL的主從復制介紹及配置MySQL的主從復制介紹及配置

    (3)在主庫上建立用于主從復制的賬號,檢查賬號建立成功。

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

MySQL的主從復制介紹及配置

    (4)主庫上鎖表,然后備份數據庫

flush table with read lock;

MySQL的主從復制介紹及配置

    鎖表后查看主庫狀態,需要記錄在案,待會復制主庫就是從這個位置開始的。

MySQL的主從復制介紹及配置

    新開一個窗口,用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復制到從庫上

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

MySQL的主從復制介紹及配置

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

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

MySQL的主從復制介紹及配置

    用vim編輯之后保存退出,然后重啟數據庫。

/etc/init.d/mysqld restart

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

MySQL的主從復制介紹及配置

    (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;

MySQL的主從復制介紹及配置

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

MySQL的主從復制介紹及配置

    (8)從庫上開啟同步開關,測試主從復制配置情況

MySQL的主從復制介紹及配置

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

MySQL的主從復制介紹及配置

MySQL的主從復制介紹及配置

    到這里,MySQL的主從配置基本完成了。下面我們在主庫上增加一個數據庫pcm_test,看看從庫會不會一起更新。證實了。

MySQL的主從復制介紹及配置MySQL的主從復制介紹及配置



向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宜兴市| 新和县| 江孜县| 台南县| 南江县| 墨竹工卡县| 永康市| 太仆寺旗| 信丰县| 蓬安县| 越西县| 宿松县| 仪征市| 盐山县| 祁连县| 北碚区| 大同县| 兴宁市| 宽城| 舞钢市| 和政县| 霍山县| 田东县| 新乐市| 阿城市| 景德镇市| 托克逊县| 时尚| 泾源县| 三都| 定边县| 酉阳| 定安县| 岗巴县| 岐山县| 福贡县| 上思县| 安福县| 孝义市| 乌鲁木齐市| 安西县|