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

溫馨提示×

溫馨提示×

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

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

MySQL中主從復制是什么

發布時間:2020-08-17 16:43:48 來源:億速云 閱讀:144 作者:小新 欄目:開發技術

這篇文章主要介紹了MySQL中主從復制是什么,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

前言:

在MySQL中,主從架構應該是最基礎、最常用的一種架構了。后續的讀寫分離、多活高可用架構等大多都依賴于主從復制。主從復制也是我們學習MySQL過程中必不可少的一部分,關于主從復制的文章有很多,筆者也來湊湊熱鬧,寫寫這方面的內容吧,同時分享下自己的經驗和方法。

1.主從復制簡介及原理

主從復制(也稱 AB 復制)是指一臺服務器充當主數據庫服務器,另一臺或多臺服務器充當從數據庫服務器,主服務器中的數據自動復制到從服務器之中。對于多級復制,數據庫服務器既可充當主機,也可充當從機。MySQL默認采用異步復制方式。

主從復制的過程及原理可以總結如下:

  1. master服務器將數據的改變記錄二進制binlog日志,當master上的數據發生改變時,則將其改變寫入二進制日志中。
  2. slave服務器會在一定時間間隔內對master二進制日志進行探測其是否發生改變,如果發生改變,則開始一個I/OThread請求master二進制事件。
  3. 同時主節點為每個I/O線程啟動一個dump線程,用于向其發送二進制事件,并保存至從節點本地的中繼日志中,從節點將啟動SQL線程從中繼日志中讀取二進制日志,在本地重放,使得其數據和主節點的保持一致。

MySQL中主從復制是什么

 2.基于二進制文件位置配置主從復制

基于二進制文件位置的主從復制又可以稱為傳統復制,即從服務器依賴于主服務器的binlog文件位置,當主庫發生數據變更時,binlog pos位點會增長,從庫會感應到變化來完成同步。

配置主從復制,我們首先要準備至少兩臺MySQL實例,一臺充當主服務器、一臺充當從服務器。由于主從復制依賴于binlog,所以主庫必須開啟binlog,且主從要配置不同的server_id,下面具體展示下配置過程:

2.1 確認主從庫配置參數

MySQL主從服務器建議有如下配置,可以先確認下,如果未配置,則需要修改配置文件然后重啟。

# 主庫參數配置 要有以下參數
vim /etc/my.cnf 
[mysqld] 
log-bin = binlog //啟用二進制日志
server-id = 137 //服務器唯一ID,默認值是1,一般設置為IP地址的最后一段數字
binlog_format = row //bilog設置為row模式 防止復制出錯

# 從庫建議配置以下參數
vim /etc/my.cnf 
[mysqld] 
relay-log = relay-bin
server-id = 138

2.2 確定主庫二進制位置,創建同步賬號

若主從庫都是剛剛初始化完成,且主庫無操作時,從庫可不用同步主庫的數據,直接確定主庫的binlog位置即可。

# 查看主庫binlog文件位置
show master status;

# 主庫創建同步賬號
create user 'repl'@'%' identified by '123456';
grant replication slave on *.* to 'repl'@'%';

若主庫已經運行了一段時間,有業務數據在,而從庫剛剛初始化完成,此時則需要備份主庫的數據,然后導入從庫,使得主從數據一致。

# 主庫創建同步賬號
create user 'repl'@'%' identified by '123456';
grant replication slave on *.* to 'repl'@'%';

# 全備主庫數據
mysqldump -uroot -pxxxx -A -R -E --single-transaction --master-data=2 > all_db.sql

# 從庫端恢復
mysql -uroot -pxxxx < all_db.sql

# 從備份文件中可以找到主庫的binlog位置

2.3 進入從庫,開啟主從復制

找到主庫二進制文件位置且完成主從數據一致后,我們就可以正式開啟主從復制了。

# 進入從庫MySQL命令行 執行change master語句連接主庫
# 二進制文件名及pos位置由上面步驟獲得
CHANGE MASTER TO MASTER_HOST='MySQL主服務器IP地址',
 MASTER_PORT=3306,
 MASTER_USER='repl',
 MASTER_PASSWORD='123456',
 MASTER_LOG_FILE='binlog.000002',
 MASTER_LOG_POS=154;
 
# 開啟主從復制 并堅持狀態
start slave;
show slave status \G //查看slave狀態 確保Slave_IO_Running: Yes Slave_SQL_Running: Yes

3.基于GTID的主從復制

GTID是MySQL 5.6的新特性,其全稱是Global Transaction Identifier,可簡化MySQL的主從切換以及Failover。GTID用于在binlog中唯一標識一個事務。當事務提交時,MySQL Server在寫binlog的時候,會先寫一個特殊的Binlog Event,類型為GTID_Event,指定下一個事務的GTID,然后再寫事務的Binlog。

在基于GTID的復制中,首先從服務器會告訴主服務器已經在從服務器執行完了哪些事務的GTID值,然后主庫會有把所有沒有在從庫上執行的事務,發送到從庫上進行執行,并且使用GTID的復制可以保證同一個事務只在指定的從庫上執行一次,這樣可以避免由于偏移量的問題造成數據不一致。也就是說,無論是級聯情況,還是一主多從的情況,都可以通過GTID自動找位置,而無需像之前那樣通過File_name和File_position找主庫binlog位置了。

基于GTID的主從復制與上面基于二進制文件位置的主從復制搭建步驟類似,同樣簡單展示下搭建過程:

3.1 確認主從庫配置,開啟GTID

# 主庫參數配置 要有以下參數
vim /etc/my.cnf 
[mysqld] 
server-id = 137
log-bin = binlog 
binlog_format = row 
gtid-mode = ON //開啟gtid模式
enforce-gtid-consistency = ON //強制gtid一致性,用于保證啟動gitd后事務的安全 

# 從庫建議配置以下參數
vim /etc/my.cnf 
[mysqld] 
server-id = 138
log-bin = binlog 
binlog_format = row 
gtid-mode = ON 
enforce-gtid-consistency = ON 
relay-log = relay-bin

3.2 創建同步賬號,保持主從庫數據一致

若主庫剛初始化完成或者主庫端保留有全部二進制文件,則從庫無需手動同步數據。否則需要手動同步數據使得主從一致。

# 主庫創建同步賬號
create user 'repl'@'%' identified by '123456';
grant replication slave on *.* to 'repl'@'%';

# 若主庫剛初始化或保留有完整二進制文件 則無需執行下面步驟
# 全備主庫數據
mysqldump -uroot -pxxxx -A -R -E --single-transaction > all_db.sql
# 從庫端恢復
mysql -uroot -pxxxx < all_db.sql

3.3 進入從庫,開啟主從復制

# 進入從庫MySQL命令行 執行change master語句連接主庫
CHANGE MASTER TO MASTER_HOST='MySQL主服務器IP地址',
 MASTER_PORT=3306,
 MASTER_USER='repl',
 MASTER_PASSWORD='123456',
 MASTER_AUTO_POSITION = 1;
 
# 開啟主從復制 并堅持狀態
start slave;
show slave status \G

 4.一些經驗及建議

在日常學習及工作過程中,主從復制方面也積累了一些經驗,下面簡單分享幾點,希望各位少踩坑。

  • 主從兩端數據庫版本盡量保持一致。
  • 主從庫參數建議相同,比如字符集、sql_mode這類參數要設置一樣。
  • 從庫服務器性能不能過于落后主庫,以免因服務器性能產生主從延遲。
  • 所有表強制擁有主鍵,因為無主鍵表同步到從庫極易產生主從延遲。
  • 建議從庫設為read only,以防人為誤操作從庫數據。
  • 監控主從延遲及狀態,及時解決同步中斷或延遲問題

感謝你能夠認真閱讀完這篇文章,希望小編分享MySQL中主從復制是什么內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節

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

AI

乾安县| 从江县| 波密县| 库尔勒市| 鄂托克旗| 申扎县| 洱源县| 成武县| 新和县| 蕲春县| 沐川县| 乌恰县| 来宾市| 桃源县| 南安市| 泾源县| 樟树市| 东乌| 东海县| 宜宾县| 昌乐县| 泗洪县| 普安县| 阿合奇县| 遂川县| 云梦县| 乌鲁木齐市| 巨野县| 海丰县| 西城区| 化隆| 平和县| 安庆市| 同仁县| 麻栗坡县| 彭泽县| 蛟河市| 玛沁县| 恩平市| 乐安县| 武山县|