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

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL 數(shù)據(jù)庫(kù)雙主改造實(shí)例

2024-07-24 12:39:28
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

下面小編一起為各位介紹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ù)

  1.    Server A: 
  2. mysqldump -uroot -p --all-databases > a_dbdump_all.sql 
  3. gzip a_dbdump_all.sql 
  4.    Server B: 
  5. mysqldump -uroot -p --all-databases > b_dbdump_all.sql 
  6. 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)

  1. Server A: 
  2. NT REPLICATION SLAVE ON *.* TO 'userx'@'server_b' IDENTIFIED BY 'xxxxx';  --Vevb.com 
  3. Server B: 
  4. 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ù))同步.

  1.    Server A: 
  2. mysqldump -uroot -p --databases db1 > a_dbdump.sql 
  3. scp a_dbdump.sql test@server_b:~ 
  4.    Server B: 
  5. mysqldump -uroot -p --databases db2 > b_dbdump.sql 
  6. scp b_dbdump.sql test@server_a:~ 
  7.    Server A: 
  8. source b_dbdump.sql 
  9.    Server B: 
  10. source a_dbdump.sql 

5.修改 MYSQL 配置

  1. Server A: 
  2. [mysqld] 
  3. server-id=1 
  4. log-bin=mysql-bin 
  5. log-slave-updates 
  6. binlog-ignore-db=mysql 
  7. binlog-ignore-db=test 
  8. binlog-ignore-db=information_schema 
  9. binlog-ignore-db=performance_schema 
  10. replicate-ignore-db=mysql 
  11. replicate-ignore-db=test 
  12. replicate-ignore-db=information_schema 
  13. replicate-ignore-db=performance_schema 
  14. master-connect-retry=10 
  15. Server B: 
  16. [mysqld] 
  17. server-id=2 
  18. log-bin=mysql-bin 
  19. log-slave-updates 
  20. binlog-ignore-db=mysql 
  21. binlog-ignore-db=test 
  22. binlog-ignore-db=information_schema 
  23. binlog-ignore-db=performance_schema 
  24. replicate-ignore-db=mysql 
  25. replicate-ignore-db=test 
  26. replicate-ignore-db=information_schema 
  27. replicate-ignore-db=performance_schema 
  28. master-connect-retry=10 

注意,他們的 server-id 不相同.

6.重啟 MYSQL, 測(cè)試同步賬號(hào)可用

重啟 MySQL.

  1. Server A: 
  2. ql -hserver_b -uuserx -pxxxxx 
  3. Server B: 
  4. ql -hserver_a -uuserx -pxxxxx 

7.啟動(dòng) SLAVE 線(xiàn)程

  1.    Server A: 
  2. FLUSH TABLES; 
  3. show master status; 
  4.    會(huì)顯示這樣的信息. 
  5. *************************** 1. row *************************** 
  6.             File: mysql-bin.000001 
  7.         Position: 106 
  8.     Binlog_Do_DB:  
  9. Binlog_Ignore_DB: mysql,test,information_schema,performance_schema 
  10. 1 row in set (0.00 sec) 

記錄 File 和 Position, 這時(shí) binlog 的當(dāng)前位置,因?yàn)?Slave 要從這個(gè)位置開(kāi)始同步數(shù)據(jù).

  1.    Server B: 
  2. CHANGE MASTER TO MASTER_HOST='server_a'
  3. CHANGE MASTER TO MASTER_USER='userx'
  4. CHANGE MASTER TO MASTER_PASSWORD='xxxxx'
  5. CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=106; 
  6. start slave; 
  7. 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ù).

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 依兰县| 龙泉市| 辽源市| 雷州市| 新竹市| 大同县| 玛纳斯县| 桓台县| 濉溪县| 滁州市| 普兰店市| 沙洋县| 荥阳市| 库伦旗| 贵溪市| 江陵县| 玉龙| 宁南县| 沛县| 平和县| 肥西县| 宁强县| 阳曲县| 周至县| 凯里市| 潜江市| 盘山县| 浦北县| 诸城市| 修武县| 镇平县| 汤原县| 新津县| 绿春县| 双辽市| 象山县| 郑州市| 双城市| 镇巴县| 达拉特旗| 襄垣县|