欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL復(fù)制的概述、安裝、故障、技巧、工具(火丁分享)

 更新時(shí)間:2011年04月06日 16:22:15   作者:  
首先主服務(wù)器把數(shù)據(jù)變化記錄到主日志,然后從服務(wù)器通過(guò)I/O線程讀取主服務(wù)器上的主日志,并且把它寫(xiě)入到從服務(wù)器的中繼日志中,接著SQL線程讀取中繼日志,并且在從服務(wù)器上重放,從而實(shí)現(xiàn)MySQL復(fù)制。
同MongoDB,Redis這樣的NoSQL數(shù)據(jù)庫(kù)的復(fù)制相比,MySQL復(fù)制顯得相當(dāng)復(fù)雜!

概述

首先主服務(wù)器把數(shù)據(jù)變化記錄到主日志,然后從服務(wù)器通過(guò)I/O線程讀取主服務(wù)器上的主日志,并且把它寫(xiě)入到從服務(wù)器的中繼日志中,接著SQL線程讀取中繼日志,并且在從服務(wù)器上重放,從而實(shí)現(xiàn)MySQL復(fù)制。具體如下圖所示:

整個(gè)過(guò)程反映到從服務(wù)器上,對(duì)應(yīng)三套日志信息,可在從服務(wù)器上用如下命令查看:
復(fù)制代碼 代碼如下:

mysql> SHOW SLAVE STATUS;


Master_Log_File & Read_Master_Log_Pos:下一個(gè)傳輸?shù)闹魅罩拘畔ⅰ?
Relay_Master_Log_File & Exec_Master_Log_Pos:下一個(gè)執(zhí)行的主日志信息。
Relay_Log_File & Relay_Log_Pos:下一個(gè)執(zhí)行的中繼日志信息。
理解這些日志信息的含義對(duì)于解決故障至關(guān)重要,后文會(huì)詳細(xì)闡述。
安裝
先在主服務(wù)器上創(chuàng)建復(fù)制賬號(hào):
復(fù)制代碼 代碼如下:

mysql> GRANT REPLICATION SLAVE ON *.*
TO '<SLAVE_USER>'@'<SLAVE_HOST>'
IDENTIFIED BY '<SLAVE_PASSWORD>';

注:出于安全性和靈活性的考慮,不要把root等具有SUPER權(quán)限用戶作為復(fù)制賬號(hào)。然后設(shè)置主服務(wù)器配置文件(缺省:/etc/my.cnf):
復(fù)制代碼 代碼如下:

[mysqld]

server_id = 100
log_bin = mysql-bin
log_bin_index = mysql-bin.index
sync_binlog = 1
innodb_flush_log_at_trx_commit = 1
innodb_support_xa = 1

注:一定要保證主從服務(wù)器各自的server_id唯一,避免沖突。

注:如果沒(méi)有指定log_bin的話,缺省會(huì)使用主機(jī)名作為名字,如此一來(lái)一旦主機(jī)名發(fā)生改變,就會(huì)出問(wèn)題,所以推薦指定log_bin(從服務(wù)器的relay_log存在一樣的問(wèn)題)。

注:sync_binlog,innodb_flush_log_at_trx_commitinnodb_support_xa三個(gè)選項(xiàng)都是出于安全目的設(shè)置的,不是復(fù)制的必須選項(xiàng)。

接著設(shè)置從服務(wù)器配置文件(缺?。?etc/my.cnf):

復(fù)制代碼 代碼如下:

[mysqld]
server_id = 200
log_bin = mysql-bin
log_bin_index = mysql-bin.index
relay_log = mysql-relay-bin
relay_log_index = mysql-relay-bin.index
read_only = 1
skip_slave_start = 1
log_slave_updates = 1

注:如果用戶有SUPER權(quán)限,則read_only無(wú)效。

注:有了skip_slave_start,除非使用START SLAVE命令,否則從服務(wù)器不會(huì)開(kāi)始復(fù)制。

注:設(shè)置log_slave_updates,讓從服務(wù)器記錄日志,有助于在必要時(shí)把從切換成主。

下面最重要的步驟是如何克隆一份主服務(wù)器的數(shù)據(jù):

如果數(shù)據(jù)庫(kù)使用的是MyISAM表類型的話,可按如下方式操作:

復(fù)制代碼 代碼如下:

shell> mysqldump --all-databases --master-data=1 > data.sql

注:master-data選項(xiàng)缺省會(huì)打開(kāi)lock-all-tables,并寫(xiě)入CHANGE MASTER TO語(yǔ)句。

如果數(shù)據(jù)庫(kù)使用的是InnoDB表類型的話,則應(yīng)該使用single-transcation

復(fù)制代碼 代碼如下:

shell> mysqldump --all-databases --single-transaction --master-data=1 > data.sql

有了數(shù)據(jù)文件,傳輸?shù)綇姆?wù)器上并導(dǎo)入:
復(fù)制代碼 代碼如下:

shell> mysql < data.sql

如果數(shù)據(jù)量很大的話,mysqldump會(huì)非常慢,此時(shí)直接拷貝數(shù)據(jù)文件能節(jié)省不少時(shí)間:
在拷貝之前要先鎖定數(shù)據(jù),然后再獲得相關(guān)的日志信息(FILE & POSITION):
復(fù)制代碼 代碼如下:

mysql> FLUSH TABLES WITH READ LOCK;
mysql> SHOW MASTER STATUS;

接下來(lái)拷貝數(shù)據(jù)文件時(shí),如果是MyISAM表類型的話,直接拷貝即可;如果是InnoDB表類型的話,一定要先停止MySQL服務(wù)再拷貝,否則拷貝文件可能無(wú)法使用。把拷貝的數(shù)據(jù)文件直接復(fù)制到從服務(wù)器的數(shù)據(jù)目錄。
最后還需要再指定一下日志信息:
復(fù)制代碼 代碼如下:

mysql> CHANGE MASTER TO
MASTER_HOST='<MASTER_HOST>',
MASTER_USER='<SLAVE_USER>',
MASTER_PASSWORD='<SLAVE_PASSWORD>',
MASTER_LOG_FILE='<FILE>',
MASTER_LOG_POS=<POSITION>;



注:不要在my.cnf配置文件里設(shè)置MASTER_USER和MASTER_PASSWORD,因?yàn)樽罱K生效的是CHANGE MASTER TO生成的master.info文件里的信息。

在主服務(wù)器上直接拷貝數(shù)據(jù)文件雖然很快,但需要鎖表或者停止服務(wù),這會(huì)影響線上服務(wù)。如果先前已經(jīng)有了從服務(wù)器,那么可以用舊的從服務(wù)器做母本來(lái)克隆新的從服務(wù)器:

先在舊的從服務(wù)器上查詢?nèi)罩拘畔ⅲ?
復(fù)制代碼 代碼如下:

mysql> SHOW SLAVE STATUS;



我們需要的是其中的Relay_Master_Log_File & Exec_Master_Log_Pos。

然后在舊的從服務(wù)器上按照前面的方法得到數(shù)據(jù),并在新的從服務(wù)器上還原。

接著在新的從服務(wù)器上設(shè)置日志信息:
復(fù)制代碼 代碼如下:

mysql> CHANGE MASTER TO
MASTER_HOST='<MASTER_HOST>',
MASTER_USER='<SLAVE_USER>',
MASTER_PASSWORD='<SLAVE_PASSWORD>',
MASTER_LOG_FILE='<Relay_Master_Log_File>',
MASTER_LOG_POS=<Exec_Master_Log_Pos>;


不管用那個(gè)方法,最后記得在從服務(wù)器上啟動(dòng)復(fù)制,并檢查工作是否正常:
復(fù)制代碼 代碼如下:

mysql> START SLAVE;
mysql> SHOW SLAVE STATUS;

如果IO線程和SQL線程都顯示Yes,就可以感謝上帝了:

Slave_IO_Running 對(duì)應(yīng):Master_Log_File & Read_Master_Log_Pos

Slave_SQL_Running 對(duì)應(yīng):Relay_Master_Log_File & Exec_Master_Log_Pos

如果顯示No,則說(shuō)明前面某些配置步驟出錯(cuò),或者對(duì)應(yīng)的日志文件有問(wèn)題。

故障

問(wèn)題:主從復(fù)制不止何故停止了,我該怎么辦?

答案:復(fù)制錯(cuò)誤多半是因?yàn)槿罩惧e(cuò)誤引起的,所以首先要搞清楚是主日志錯(cuò)誤還是中繼日志錯(cuò)誤,從錯(cuò)誤信息里一般就能判斷,如果不能可以使用類似下面的mysqlbinlog命令:
復(fù)制代碼 代碼如下:

shell> mysqlbinlog <MASTER_BINLOG_FILE> > /dev/null
shell> mysqlbinlog <SLAVE_BINLOG_FILE> > /dev/null

如果沒(méi)有錯(cuò)誤,則不會(huì)有任何輸出,反之如果有錯(cuò)誤,則會(huì)顯示出來(lái)。
如果是主日志錯(cuò)誤,則需要在從服務(wù)器使用SET GLOBAL sql_slave_skip_counter,如下:
復(fù)制代碼 代碼如下:

mysql> SET GLOBAL sql_slave_skip_counter = 1;
mysql> START SLAVE;


注:如果有多個(gè)錯(cuò)誤,可能需要執(zhí)行多次(提醒:主從服務(wù)器數(shù)據(jù)可能因此不一致)。
如果是中繼日志錯(cuò)誤,只要在從服務(wù)器使用SHOW SLAVE STATUS結(jié)果中的日志信息重新CHANGE MASTER TO即可,系統(tǒng)會(huì)拋棄當(dāng)前的中繼日志,重新下載:
復(fù)制代碼 代碼如下:

mysql> CHANGE MASTER TO
MASTER_LOG_FILE='<Relay_Master_Log_File>',
MASTER_LOG_POS=<Exec_Master_Log_Pos>;
mysql> START SLAVE;


至于為什么使用的是Relay_Master_Log_File & Exec_Master_Log_Pos,參見(jiàn)概述。
問(wèn)題:主服務(wù)器宕機(jī)了,如何把從服務(wù)器提升會(huì)主服務(wù)器?
答案:在一主多從的環(huán)境總,需選擇數(shù)據(jù)最新的從服務(wù)器做新的主服務(wù)器。如下圖所示:

提升從服務(wù)器為主服務(wù)器

在一主(Server1)兩從(Server2,、Server3)的環(huán)境中,Server1宕機(jī)后,等到Server1和Server2把宕機(jī)前同步到的日志都執(zhí)行完,比較Master_Log_File和Read_Master_Log_Pos就可以判斷出誰(shuí)快誰(shuí)慢,因?yàn)镾erver2從 Server1同步的數(shù)據(jù)(1582)比Server3從Server1同步的數(shù)據(jù)(1493)新,所以應(yīng)該提升Server2為新的主服務(wù)器,那么 Server3在CHANGE MASTER TO到Server2的時(shí)候應(yīng)該使用什么樣的參數(shù)呢?1582-1493=89,而Server2的最后的二進(jìn)制日志位置是8167,所以答案是 8167-89=8078。

技巧

主從服務(wù)器中的表可以使用不同的表類型。比如主服務(wù)器可以使用InnoDB表類型,提供事務(wù),行鎖等高級(jí)特性,從服務(wù)器可以使用MyISAM表類型,內(nèi)存消耗少,易備份等優(yōu)點(diǎn)。還有一個(gè)例子,一臺(tái)主服務(wù)器如果同時(shí)帶很多個(gè)從服務(wù)器的話,勢(shì)必會(huì)影響其性能,此時(shí)可以拿出一臺(tái)服務(wù)器作為從服務(wù)器代理,使用BLACKHOLE表類型,只記錄日志,不寫(xiě)數(shù)據(jù),由它帶多臺(tái)從服務(wù)器,從而提升性能。

主從服務(wù)器中的表可以使用不同的鍵類型。比如主服務(wù)器用InnoDB,鍵用VARCHAR的話節(jié)省空間,從服務(wù)器使用MyISAM,鍵用CHAR提高速度,因?yàn)镸yISAM有靜態(tài)表一說(shuō)。

主從服務(wù)器中的表可以使用不同的索引。主服務(wù)器主要用來(lái)應(yīng)付寫(xiě)操作,所以除了主鍵和唯一索引等保證數(shù)據(jù)關(guān)系的索引一般都可以不加,從服務(wù)器一般用來(lái)應(yīng)付讀操作,所以可以針對(duì)查詢特征設(shè)置索引,再進(jìn)一步,不同的從服務(wù)器可以針對(duì)不同的查詢?cè)O(shè)置不同的索引。

工具

有一些優(yōu)秀的工具可以讓你的復(fù)制工作得到事半功倍的效果,詳細(xì)內(nèi)容請(qǐng)參考各自文檔:

Multi-Master Replication Manager for MySQL

Percona XtraBackup

Maatkit

Tungsten-replicator

此外,Google Project Hosting里還有很多有趣的項(xiàng)目,可用mysql+replication標(biāo)簽搜索。

說(shuō)明:本文參考了下面列出的書(shū)籍中相關(guān)的內(nèi)容:

High Performance MySQL: Optimization, Backups, Replication, and More

MySQL High Availability: Tools for Building Robust Data Centers

(來(lái)源:火丁筆記

相關(guān)文章

  • 通過(guò)唯一索引S鎖與X鎖來(lái)了解MySQL死鎖套路

    通過(guò)唯一索引S鎖與X鎖來(lái)了解MySQL死鎖套路

    毫不夸張的說(shuō),有一半以上的死鎖問(wèn)題由唯一索引貢獻(xiàn),后面介紹的很多死鎖的問(wèn)題都跟唯一索引有關(guān)。這次我們講一段唯一索引 S 鎖與 X 鎖的案例,下面小編來(lái)和大家一起學(xué)習(xí)一下
    2019-05-05
  • mysql中取字符串中的數(shù)字的語(yǔ)句

    mysql中取字符串中的數(shù)字的語(yǔ)句

    在很多時(shí)間我們需要把字符串的數(shù)字給取出來(lái),通常大家會(huì)用php,asp等這類來(lái)操作,本文章介紹了在sql中取字符中的數(shù)字辦法,有需要的朋友可以參考一下
    2012-04-04
  • MySQL詳解進(jìn)行JDBC編程與增刪改查方法

    MySQL詳解進(jìn)行JDBC編程與增刪改查方法

    JDBC是指Java數(shù)據(jù)庫(kù)連接,是一種標(biāo)準(zhǔn)Java應(yīng)用編程接口( JAVA API),用來(lái)連接 Java 編程語(yǔ)言和廣泛的數(shù)據(jù)庫(kù)。從根本上來(lái)說(shuō),JDBC 是一種規(guī)范,它提供了一套完整的接口,允許便攜式訪問(wèn)到底層數(shù)據(jù)庫(kù)
    2022-06-06
  • mysql 觸發(fā)器語(yǔ)法與應(yīng)用示例

    mysql 觸發(fā)器語(yǔ)法與應(yīng)用示例

    這篇文章主要介紹了mysql 觸發(fā)器語(yǔ)法與應(yīng)用,結(jié)合實(shí)例形式詳細(xì)分析了mysql 觸發(fā)器的基本語(yǔ)法與插入、更細(xì)、刪除等相關(guān)操作技巧,需要的朋友可以參考下
    2020-05-05
  • MYSQL根據(jù)JSON列將一行拆為多行的操作方法

    MYSQL根據(jù)JSON列將一行拆為多行的操作方法

    這篇文章主要介紹了MYSQL根據(jù)JSON列將一行拆為多行的操作方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06
  • mysql查詢FIND_IN_SET?REGEXP實(shí)踐示例

    mysql查詢FIND_IN_SET?REGEXP實(shí)踐示例

    這篇文章主要為大家介紹了mysql查詢FIND_IN_SET?REGEXP實(shí)踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • MySQL 外鍵(FOREIGN KEY)用法案例詳解

    MySQL 外鍵(FOREIGN KEY)用法案例詳解

    這篇文章主要介紹了MySQL 外鍵(FOREIGN KEY)用法案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 關(guān)于mysql delete的問(wèn)題小結(jié)

    關(guān)于mysql delete的問(wèn)題小結(jié)

    關(guān)于mysql delete的問(wèn)題,需要的朋友可以參考下。
    2011-05-05
  • 深入sql數(shù)據(jù)連接時(shí)的一些問(wèn)題分析

    深入sql數(shù)據(jù)連接時(shí)的一些問(wèn)題分析

    本篇文章是對(duì)關(guān)于sql數(shù)據(jù)連接時(shí)的一些問(wèn)題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • SQL 語(yǔ)句優(yōu)化方法30例

    SQL 語(yǔ)句優(yōu)化方法30例

    在SQL語(yǔ)句優(yōu)化過(guò)程中,我們經(jīng)常會(huì)用到hint,現(xiàn)總結(jié)一下在SQL優(yōu)化過(guò)程中常見(jiàn)Oracle HINT的用法.
    2009-10-10

最新評(píng)論