MySQL 數據庫雙主改造

jopen 10年前發布 | 14K 次閱讀 MySQL 數據庫服務器

對于使用中的已有了一些數據庫的 MySQL, 如何改造成雙主呢? 這里寫一篇文章, 詳細記錄操作步驟. 聽取各位的意見.

這里假設有兩臺服務器: A 和 B. 要讓他們互為主, 但實際使用時, 不同的服務器只服務不同的 db, 避免出現數據沖突.

1. 修改 nginx 配置, 掛維護頁

這一步很重要. 你需要告訴你的用戶, 你的網站在維護, 同時要確保不會再出現數據庫寫操作.

另外, 還要停止 crontab 任務.

2. 備份數據庫

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

把線上數據庫備份到本地

scp test@server_a:~/a_dbdump_all.sql.gz .
scp test@server_b:~/b_dbdump_all.sql.gz .

3. 新建數據庫同步賬號

Server A:

GRANT REPLICATION SLAVE ON *.* TO 'userx'@'server_b' IDENTIFIED BY 'xxxxx';

Server B:

GRANT REPLICATION SLAVE ON *.* TO 'userx'@'server_a' IDENTIFIED BY 'xxxxx';

4. 導數據

這一步是手工將兩臺服務器數據庫(基準數據)同步.

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, 測試同步賬號可用

重啟 MySQL.

Server A:

mysql -hserver_b -uuserx -pxxxxx

Server B:

mysql -hserver_a -uuserx -pxxxxx

7. 啟動 Slave 線程

Server A:

FLUSH TABLES;
show master status;

會顯示這樣的信息.

*************************** 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, 這時 binlog 的當前位置, 因為 Slave 要從這個位置開始同步數據.

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 上也啟動同步 Slave 進程.

因為我們確保了沒有數據庫寫操作, 所以不需要 FLUSH TABLES WITH READ LOCK;.

8. 驗證

在不同的數據庫上執行一些更新數據的操作, 看看數據是否同步過去了.

9. 完成

恢復 crontab 任務
修改 nginx, 撤下維護網頁, 恢復服務
如果你有什么問題, 或者發現里這些步驟的不足, 歡迎評論!

Related posts:

  1. MySQL 基本配置
  2. SSDB源碼分析 – 服務器的啟動過程
  3. Linux下編譯安裝Apache/Nginx/Lighttpd+PHP+MySQL
  4. MySQL 更新并返回計數
  5. 永恒的變化

原文鏈接: http://www.ideawu.net/blog/archives/841.html

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!