對(duì)于雙向數(shù)據(jù)庫(kù)鏡像,就是數(shù)據(jù)庫(kù)A的數(shù)據(jù)變化要鏡像到數(shù)據(jù)庫(kù)B中,同時(shí)數(shù)據(jù)庫(kù)B里的修改也要同時(shí)復(fù)制到數(shù)據(jù)庫(kù)A里。
對(duì)于循環(huán)數(shù)據(jù)庫(kù)鏡像,就是多個(gè)數(shù)據(jù)庫(kù)A、B、C、D等,對(duì)其中任一個(gè)數(shù)據(jù)庫(kù)的修改,都要同時(shí)鏡像到其它的數(shù)據(jù)庫(kù)里。
應(yīng)用:同一個(gè)Zen Cart網(wǎng)店的數(shù)據(jù)庫(kù)和程序,可以放置在不同的主機(jī)上,在任一臺(tái)主機(jī)上新增的訂單、客戶資料,都會(huì)同時(shí)加入其它的主機(jī)數(shù)據(jù)庫(kù)里。
要實(shí)現(xiàn)雙向或循環(huán)數(shù)據(jù)庫(kù)鏡像,首先要解決的就是防止數(shù)據(jù)庫(kù)中自動(dòng)遞增(AUTO_INCREMENT)字段的沖突,以免多數(shù)據(jù)庫(kù)各自生成一樣的增量值。
下面以三臺(tái)主機(jī)循環(huán)鏡像為例,A是B的主鏡像,B是C的主鏡像,C是A的主鏡像。三臺(tái)主機(jī)上MySQL設(shè)置文件 /etc /my.cnf 中分別加入下面的參數(shù):
# 主機(jī)一:美國(guó)主機(jī) A, IP: 100.101.102.201
[mysqld]
server-id = 10
log-bin = mysql-bin
log-slave-updates
replicate-same-server-id = 0
auto_increment_increment = 10
auto_increment_offset = 1
master-host = 100.101.102.203
master-user = repl_user
master-password = repl_password
report-host = 100.101.102.201
# 主機(jī)二:中國(guó)主機(jī) B, IP: 100.101.102.202
[mysqld]
server-id = 20
log-bin = mysql-bin
log-slave-updates
replicate-same-server-id = 0
auto_increment_increment = 10
auto_increment_offset = 2
master-host = 100.101.102.201
master-user = repl_user
master-password = repl_password
report-host = 100.101.102.202
# 主機(jī)三:本地主機(jī) C, IP: 100.101.102.203
[mysqld]
server-id = 30
log-bin = mysql-bin
log-slave-updates
replicate-same-server-id = 0
auto_increment_increment = 10
auto_increment_offset = 3
master-host = 100.101.102.202
master-user = repl_user
master-password = repl_password
report-host = 100.101.102.203
簡(jiǎn)單說明:
server-id:數(shù)據(jù)庫(kù)標(biāo)識(shí),每個(gè)數(shù)據(jù)庫(kù)標(biāo)識(shí)必須唯一;
replicate-same-server-id:設(shè)置為0,防止數(shù)據(jù)循環(huán)更新;
auto_increment_increment:這是循環(huán)鏡像里最重要的參數(shù)之一,表示自動(dòng)增量為10,這將允許最多10臺(tái)數(shù)據(jù)庫(kù)加入這個(gè)循環(huán)鏡像的陣列,而自動(dòng)遞增字段不會(huì)重復(fù)。
auto_increment_offset:這是循環(huán)鏡像里最重要的參數(shù)之一,表示偏移值,每個(gè)數(shù)據(jù)庫(kù)的偏移值必須唯一,且在1和auto_increment_increment之間。
master-host:主數(shù)據(jù)庫(kù)服務(wù)器的IP;
master-user:用于連接主數(shù)據(jù)庫(kù)的鏡像用戶名;
master-password:用于連接主數(shù)據(jù)庫(kù)的鏡像密碼;
report-host:提供給主數(shù)據(jù)庫(kù)用于反向連接的IP,因?yàn)橹鲾?shù)據(jù)庫(kù)有時(shí)無法正確判斷從服務(wù)器的IP,所以這里最好填上從服務(wù)器自己的IP地址。
另外,有時(shí)只需要鏡像某些數(shù)據(jù)庫(kù),可以在 my.cnf 中加入:
replicate-do-db = db_name1
replicate-do-db = db_name2
replicate-do-db = db_name3
這樣就僅僅鏡像db_name1/db_name2/db_name3
如果只是某些數(shù)據(jù)庫(kù)不要鏡像,可以在 my.cnf 中加入:
replicate-ignore-db=db_name1
replicate-ignore-db=db_name2
replicate-ignore-db=db_name3
這樣鏡像時(shí)就忽略 db_name1/db_name2/db_name3 這三個(gè)數(shù)據(jù)庫(kù)。
MySQL 數(shù)據(jù)庫(kù)雙向鏡像、循環(huán)鏡像(復(fù)制)
2019-11-19 15:12MYSQL教程網(wǎng) Mysql
在MySQL數(shù)據(jù)庫(kù)鏡像的貼子中,主數(shù)據(jù)庫(kù)A 的數(shù)據(jù)鏡像到從數(shù)據(jù)庫(kù)B,是單向的,Zen Cart網(wǎng)店的數(shù)據(jù)讀寫都必須在數(shù)據(jù)庫(kù)A進(jìn)行,結(jié)果會(huì)自動(dòng)鏡像到數(shù)據(jù)庫(kù)B中。但是對(duì)數(shù)據(jù)庫(kù)B的直接操作,不會(huì)影響數(shù)據(jù)庫(kù)A。
延伸 · 閱讀
- 2022-03-11MySQL的索引你了解嗎
- 2022-03-10面試中老生常談的MySQL問答集錦夯實(shí)基礎(chǔ)
- 2022-03-10淺談如何保證Mysql主從一致
- 2022-03-10Ubuntu18.04(linux)安裝MySQL的方法步驟
- 2022-03-09MySQL讓人又愛又恨的多表查詢
- 2022-03-09MySQL Server 層和存儲(chǔ)引擎層是怎么交互數(shù)據(jù)的?
- Mysql
MySQL server has gone away錯(cuò)誤提示解決方法
今天遇到類似的情景,MySQL只是冷冷的說:MySQL server has gone away。 ...
- Mysql
MySQL鎖的知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理了關(guān)于MySQL鎖的知識(shí)點(diǎn)總結(jié)以及實(shí)例內(nèi)容,需要的朋友們學(xué)習(xí)下。...
- Mysql
Centos7下使用yum安裝mysql數(shù)據(jù)庫(kù)的詳細(xì)教程(增強(qiáng)版)
這篇文章主要介紹了Centos7下使用yum安裝mysql數(shù)據(jù)庫(kù)的詳細(xì)教程(增強(qiáng)版),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下 ...
- Mysql
MySQL 查詢速度慢與性能差的原因與解決方法
隨著網(wǎng)站數(shù)據(jù)量與訪問量的增加,MySQL 查詢速度慢與性能差的問題就日漸明顯,這里為大家分享一下解決方法,需要的朋友可以參考下...
- Mysql
MySQL之Field‘***’doesn’t have a default value錯(cuò)誤解決辦法
這篇文章主要介紹了MySQL之Field‘***’doesn’t have a default value錯(cuò)誤解決辦法,需要的朋友可以參考下 ...
- Mysql
MySQL全文索引、聯(lián)合索引、like查詢、json查詢速度哪個(gè)快
這篇文章主要介紹了MySQL全文索引、聯(lián)合索引、like查詢、json查詢速度大比拼,通過實(shí)例代碼截圖的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值...
- Mysql
解決重置Mysql root用戶賬號(hào)密碼問題
這篇文章主要介紹了解決重置Mysql root用戶賬號(hào)密碼問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下...
- Mysql
幾種MySQL中的聯(lián)接查詢操作方法總結(jié)
這篇文章主要介紹了幾種MySQL中的聯(lián)接查詢操作方法總結(jié),文中包括一些代碼舉例講解,需要的朋友可以參考下 ...