下面小編一起為各位介紹MySQL 數(shù)據(jù)庫(kù)雙主改造實(shí)例,如果有興趣的可以看看,搭配方法非常的簡(jiǎn)單.
對(duì)于使用中的已有了一些數(shù)據(jù)庫(kù)的 MySQL,如何改造成雙主呢? 這里寫(xiě)一篇文章,詳細(xì)記錄操作步驟,聽(tīng)取各位的意見(jiàn).
這里假設(shè)有兩臺(tái)服務(wù)器:A 和 B. 要讓他們互為主,但實(shí)際使用時(shí),不同的服務(wù)器只服務(wù)不同的 db,避免出現(xiàn)數(shù)據(jù)沖突.
1.修改 NGINX 配置,掛維護(hù)頁(yè)
這一步很重要.你需要告訴你的用戶(hù),你的網(wǎng)站在維護(hù),同時(shí)要確保不會(huì)再出現(xiàn)數(shù)據(jù)庫(kù)寫(xiě)操作,另外,還要停止 crontab 任務(wù).
2.備份數(shù)據(jù)庫(kù)
- Server A:
- mysqldump -uroot -p --all-databases > a_dbdump_all.sql
- gzip a_dbdump_all.sql
- Server B:
- mysqldump -uroot -p --all-databases > b_dbdump_all.sql
- gzip b_dbdump_all.sql
把線(xiàn)上數(shù)據(jù)庫(kù)備份到本地
scp test@server_a:~/a_dbdump_all.sql.gz .
scp test@server_b:~/b_dbdump_all.sql.gz .
3.新建數(shù)據(jù)庫(kù)同步賬號(hào)
- Server A:
- NT REPLICATION SLAVE ON *.* TO 'userx'@'server_b' IDENTIFIED BY 'xxxxx'; --Vevb.com
- Server B:
- NT REPLICATION SLAVE ON *.* TO 'userx'@'server_a' IDENTIFIED BY 'xxxxx';
4.導(dǎo)數(shù)據(jù)
這一步是手工將兩臺(tái)服務(wù)器數(shù)據(jù)庫(kù)(基準(zhǔn)數(shù)據(jù))同步.
- Server A:
- mysqldump -uroot -p --databases db1 > a_dbdump.sql
- scp a_dbdump.sql test@server_b:~
- Server B:
- mysqldump -uroot -p --databases db2 > b_dbdump.sql
- scp b_dbdump.sql test@server_a:~
- Server A:
- source b_dbdump.sql
- Server B:
- source a_dbdump.sql
5.修改 MYSQL 配置
- Server A:
- [mysqld]
- server-id=1
- log-bin=mysql-bin
- log-slave-updates
- binlog-ignore-db=mysql
- binlog-ignore-db=test
- binlog-ignore-db=information_schema
- binlog-ignore-db=performance_schema
- replicate-ignore-db=mysql
- replicate-ignore-db=test
- replicate-ignore-db=information_schema
- replicate-ignore-db=performance_schema
- master-connect-retry=10
- Server B:
- [mysqld]
- server-id=2
- log-bin=mysql-bin
- log-slave-updates
- binlog-ignore-db=mysql
- binlog-ignore-db=test
- binlog-ignore-db=information_schema
- binlog-ignore-db=performance_schema
- replicate-ignore-db=mysql
- replicate-ignore-db=test
- replicate-ignore-db=information_schema
- replicate-ignore-db=performance_schema
- master-connect-retry=10
注意,他們的 server-id 不相同.
6.重啟 MYSQL, 測(cè)試同步賬號(hào)可用
重啟 MySQL.
- Server A:
- ql -hserver_b -uuserx -pxxxxx
- Server B:
- ql -hserver_a -uuserx -pxxxxx
7.啟動(dòng) SLAVE 線(xiàn)程
- Server A:
- FLUSH TABLES;
- show master status;
- 會(huì)顯示這樣的信息.
- *************************** 1. row ***************************
- File: mysql-bin.000001
- Position: 106
- Binlog_Do_DB:
- Binlog_Ignore_DB: mysql,test,information_schema,performance_schema
- 1 row in set (0.00 sec)
記錄 File 和 Position, 這時(shí) binlog 的當(dāng)前位置,因?yàn)?Slave 要從這個(gè)位置開(kāi)始同步數(shù)據(jù).
- Server B:
- CHANGE MASTER TO MASTER_HOST='server_a';
- CHANGE MASTER TO MASTER_USER='userx';
- CHANGE MASTER TO MASTER_PASSWORD='xxxxx';
- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=106;
- start slave;
- show slave status/G
同樣的,在 Server A 上也啟動(dòng)同步 Slave 進(jìn)程,因?yàn)槲覀兇_保了沒(méi)有數(shù)據(jù)庫(kù)寫(xiě)操作, 所以不需要 FLUSH TABLES WITH READ LOCK;.
8. 驗(yàn)證
在不同的數(shù)據(jù)庫(kù)上執(zhí)行一些更新數(shù)據(jù)的操作, 看看數(shù)據(jù)是否同步過(guò)去了.
9.完成
恢復(fù) crontab 任務(wù),修改 nginx,撤下維護(hù)網(wǎng)頁(yè),恢復(fù)服務(wù).
新聞熱點(diǎn)
疑難解答
圖片精選