婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL數(shù)據(jù)庫的實時備份知識點詳解

MySQL數(shù)據(jù)庫的實時備份知識點詳解

熱門標(biāo)簽:高德地圖標(biāo)注中心個人注冊 如何在高德地圖標(biāo)注新地址 湘潭電銷機器人咨詢電話 寶應(yīng)電信400電話辦理費用 電銷機器人針對的 外呼系統(tǒng)防封號違法嗎 外呼系統(tǒng)服務(wù) 400電話辦理都選易號網(wǎng) 高德地圖標(biāo)注模式

前言

數(shù)據(jù)庫實時備份的需求很常見,MySQL本身提供了 Replication 機制,摘譯官方介紹如下:

MySQL Replication 可以將一個主數(shù)據(jù)庫中的數(shù)據(jù)同步到一個或多個從數(shù)據(jù)庫中。并且這個同步過程默認(rèn)以異步方式工作,不需要保持主從數(shù)據(jù)庫的實時連接(即允許連接中斷)。同時允許自定義配置需同步的數(shù)據(jù)庫及數(shù)據(jù)表。

MySQL Replication 的優(yōu)點及應(yīng)用場景如下:

1、通過 MySQL Replication 實現(xiàn)負(fù)載均衡與讀寫分離(主數(shù)據(jù)庫僅更新,從數(shù)據(jù)庫僅讀取),提升數(shù)據(jù)庫性能。

2、通過 MySQL Replication 實現(xiàn)數(shù)據(jù)的實時備份,保證數(shù)據(jù)安全。

3、通過 MySQL Replication 實現(xiàn)數(shù)據(jù)的離線分析(主數(shù)據(jù)庫生成數(shù)據(jù),從數(shù)據(jù)庫分析計算不影響主數(shù)據(jù)庫性能)。

4、數(shù)據(jù)分發(fā)。

MySQL Replication完整的官方文檔請參閱:https://dev.mysql.com/doc/refman/5.7/en/replication.html

工作原理

1111

1、Master中的所有數(shù)據(jù)庫變更事件寫入Binary Log文件

2、當(dāng)在Slave中執(zhí)行“SLAVE START”命令時,開啟Slave I/O Thread,并連接Master

3、Master偵測到Slave I/O Thread的連接,開啟Log Jump Thread進行響應(yīng)

4、Master Binary Log經(jīng)Master Log Jump Thread和Slave I/O Thread傳輸至Slave Relay Log

5、Slave SQL Thread將Relay Log還原至數(shù)據(jù),同步完成

注:可使用“SHOW PROCESSLIST”命令在Master和Slave中查看對應(yīng)線程的運行情況

配置Master

開啟Binary Log并設(shè)置ServerID,ServerID必須唯一,取值范圍1至232-1

[mysqld]
# 開啟Binary Log
log-bin=mysql-bin
# 設(shè)置全局ID
server-id=1

# 指定需同步的數(shù)據(jù)庫(因為數(shù)據(jù)庫名稱可能包含逗號,因此多個數(shù)據(jù)庫必須重復(fù)配置多次而不能以逗號分隔)
binlog-do-db=database_name
# 指定禁止同步的數(shù)據(jù)庫
binlog-ignore-db=database_name
# 指定Binary Log格式
binlog_format=MIXED

創(chuàng)建同步帳號

因為每個Slave均需要使用帳號密碼連接至主數(shù)據(jù)庫,所以在主數(shù)據(jù)庫上必須提供帳號。建議使用一個獨立帳號,僅授權(quán)數(shù)據(jù)同步權(quán)限。

CREATE USER 'repl'@'%.example.com' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%.example.com';

獲取Binary Log信息

Slave啟動I/O Thread時需要傳入Binary Log部分信息,因此需要獲取一下Binary Log信息:

SHOW MASTER STATUS;

使用“SHOW MASTER STATUS”命令獲取Binary Log信息,并記錄File和Position字段值。

同步前保證Master與Slave的數(shù)據(jù)一致

在Slave啟動I/O Thread前,需確保Master與Slave的數(shù)據(jù)一致,因此先對Master進行鎖定(防止數(shù)據(jù)變更),手動同步并確保數(shù)據(jù)一致后再解鎖。

FLUSH TABLES WITH READ LOCK;

手動數(shù)據(jù)同步相關(guān)操作略...

UNLOCK TABLES;

配置Slave

設(shè)置ServerID,可不必開啟BinLog:

[mysqld]
# 設(shè)置全局ID
server-id=2

# 指定同步的數(shù)據(jù)庫
replicate-do-db=database_name
# 指定禁止同步的數(shù)據(jù)庫
replicate_ignore_db=database_name

設(shè)置Master信息,執(zhí)行如下命令:

mysql> CHANGE MASTER TO
  ->   MASTER_HOST='master_host_name',
  ->   MASTER_PORT='master_host_port',
  ->   MASTER_USER='replication_user_name',
  ->   MASTER_PASSWORD='replication_password',
  ->   MASTER_LOG_FILE='recorded_log_file_name',
  ->   MASTER_LOG_POS=recorded_log_position;

啟動I/O Thread

START SLAVE;

查看同步狀態(tài):

SHOW SLAVE STATUS;

Master的binlog_format 參數(shù)

binlog_format用于配置Binary Log的格式,支持如下三種類型:

Row

按數(shù)據(jù)行的變化進行記錄,該模式與SQL語句、存儲過程、函數(shù)、觸發(fā)器等無關(guān),它只關(guān)心每一行的數(shù)據(jù)是否發(fā)生變化,如變化則記錄,因此Row模式是準(zhǔn)確度最高的。但它的缺點是某些情況下會產(chǎn)生大量內(nèi)容而導(dǎo)致效率下降,比如表結(jié)構(gòu)發(fā)生變更時。

Statement

按SQL語句進行記錄,很明顯這個解決了Row模式的短板,但問題是準(zhǔn)確度不夠高,因為SQL語句可以非常復(fù)雜并且容易出現(xiàn)意外情況。

Mixed

Row與Statement混合模式,由MySQL自動決定什么時候使用Row,什么時候使用Statement,這也是默認(rèn)模式。

replicate-do-db注意事項

當(dāng)在Slave中使用replicate-do-db和replicate-ignore-db配置項時,需特別注意,跨數(shù)據(jù)庫的SQL語句將不會被同步,如:

replicate-do-db=a
use b;
update a.some_table set some_field = 'some value';

解決方案是使用replicate_wild_do_table和replicate_wild_ignore_table,如:

replicate_wild_do_table=database_name.%
replicate_wild_ignore_table=database_name.%

您可能感興趣的文章:
  • mysql備份的三種方式詳解
  • MySql數(shù)據(jù)庫備份的幾種方式
  • mysql 數(shù)據(jù)庫備份的多種實現(xiàn)方式總結(jié)
  • MySQL數(shù)據(jù)庫入門之備份數(shù)據(jù)庫操作詳解
  • MySQL學(xué)習(xí)之?dāng)?shù)據(jù)庫備份詳解

標(biāo)簽:黃山 賀州 黔南 蘭州 佛山 宿遷 南充 馬鞍山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL數(shù)據(jù)庫的實時備份知識點詳解》,本文關(guān)鍵詞  MySQL,數(shù)據(jù)庫,的,實時,備份,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL數(shù)據(jù)庫的實時備份知識點詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL數(shù)據(jù)庫的實時備份知識點詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 库伦旗| 游戏| 新疆| 全南县| 揭东县| 鄂托克前旗| 合川市| 屯昌县| 阿勒泰市| 五大连池市| 万盛区| 霍山县| 安仁县| 靖宇县| 洞口县| 迁西县| 海宁市| 浦县| 旅游| 繁峙县| 夏邑县| 延安市| 临颍县| 深圳市| 鲜城| 邢台市| 宜川县| 积石山| 武义县| 油尖旺区| 柳江县| 横峰县| 长子县| 湖州市| 浦北县| 海门市| 浮梁县| 太仆寺旗| 延长县| 海口市| 大田县|