国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL 數據庫雙向鏡像、循環鏡像(復制)

2024-07-24 13:03:16
字體:
來源:轉載
供稿:網友
對于雙向數據庫鏡像,就是數據庫A的數據變化要鏡像到數據庫B中,同時數據庫B里的修改也要同時復制到數據庫A里。

  對于循環數據庫鏡像,就是多個數據庫A、B、C、D等,對其中任一個數據庫的修改,都要同時鏡像到其它的數據庫里。

應用:同一個Zen Cart網店的數據庫和程序,可以放置在不同的主機上,在任一臺主機上新增的訂單、客戶資料,都會同時加入其它的主機數據庫里。

  要實現雙向或循環數據庫鏡像,首先要解決的就是防止數據庫中自動遞增(AUTO_INCREMENT)字段的沖突,以免多數據庫各自生成一樣的增量值。

  下面以三臺主機循環鏡像為例,A是B的主鏡像,B是C的主鏡像,C是A的主鏡像。三臺主機上MySQL設置文件 /etc /my.cnf 中分別加入下面的參數:

# 主機一:美國主機 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

# 主機二:中國主機 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

# 主機三:本地主機 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


簡單說明:
server-id:數據庫標識,每個數據庫標識必須唯一;
replicate-same-server-id:設置為0,防止數據循環更新;
auto_increment_increment:這是循環鏡像里最重要的參數之一,表示自動增量為10,這將允許最多10臺數據庫加入這個循環鏡像的陣列,而自動遞增字段不會重復。
auto_increment_offset:這是循環鏡像里最重要的參數之一,表示偏移值,每個數據庫的偏移值必須唯一,且在1和auto_increment_increment之間。
master-host:主數據庫服務器的IP;
master-user:用于連接主數據庫的鏡像用戶名;
master-password:用于連接主數據庫的鏡像密碼;
report-host:提供給主數據庫用于反向連接的IP,因為主數據庫有時無法正確判斷從服務器的IP,所以這里最好填上從服務器自己的IP地址。


另外,有時只需要鏡像某些數據庫,可以在 my.cnf 中加入:
replicate-do-db = db_name1
replicate-do-db = db_name2
replicate-do-db = db_name3

這樣就僅僅鏡像db_name1/db_name2/db_name3


如果只是某些數據庫不要鏡像,可以在 my.cnf 中加入:
replicate-ignore-db=db_name1
replicate-ignore-db=db_name2
replicate-ignore-db=db_name3

這樣鏡像時就忽略 db_name1/db_name2/db_name3 這三個數據庫。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 大兴区| 长汀县| 太湖县| 温州市| 罗源县| 九龙县| 民县| 太原市| 腾冲县| 乌拉特后旗| 梁山县| 昭平县| 天峨县| 齐河县| 永安市| 历史| 固安县| 大城县| 元江| 灵川县| 芜湖市| 米泉市| 虹口区| 平谷区| 长汀县| 开封县| 双柏县| 丰城市| 东方市| 济南市| 简阳市| 江安县| 那曲县| 米脂县| 根河市| 门源| 集贤县| 罗平县| 兴城市| 措美县| 体育|