成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL 數(shù)據(jù)庫(kù)雙主配置

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

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

  這里假設(shè)有兩臺(tái)服務(wù)器: A 和 B. 要讓他們互為主, 但實(shí)際使用時(shí), 不同的服務(wù)器只服務(wù)不同的 db, 避免出現(xiàn)數(shù)據(jù)沖突.

  如果想增加一個(gè)從庫(kù), 可參考此篇: MySQL 在線增加從庫(kù).

  1. 修改 nginx 配置, 掛維護(hù)頁(yè)

  這一步很重要. 你需要告訴你的用戶, 你的網(wǎng)站在維護(hù), 同時(shí)要確保不會(huì)再出現(xiàn)數(shù)據(jù)庫(kù)寫操作.

  另外, 還要停止 crontab 任務(wù).

  2. 備份數(shù)據(jù)庫(kù)

  Server A:

 

  1. mysqldump -uroot -p --all-databases > a_dbdump_all.sql 
  2. gzip a_dbdump_all.sql 

 

  Server B:

 

  1. mysqldump -uroot -p --all-databases > b_dbdump_all.sql 
  2. gzip b_dbdump_all.sql 

 

  把線上數(shù)據(jù)庫(kù)備份到本地

 

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

 

  3. 新建數(shù)據(jù)庫(kù)同步賬號(hào)

  Server A:

 

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

  Server B:

 

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

  4. 修改 mysql 配置

  Server A:

 

  1. [mysqld] 
  2. server-id=1 
  3. log-bin=mysql-bin 
  4. log-slave-updates 
  5. binlog-ignore-db=mysql 
  6. binlog-ignore-db=test 
  7. binlog-ignore-db=information_schema 
  8. binlog-ignore-db=performance_schema 
  9. replicate-ignore-db=mysql 
  10. replicate-ignore-db=test 
  11. replicate-ignore-db=information_schema 
  12. replicate-ignore-db=performance_schema 
  13. master-connect-retry=10 

 

  Server B:

 

  1. [mysqld] 
  2. server-id=2 
  3. log-bin=mysql-bin 
  4. log-slave-updates 
  5. binlog-ignore-db=mysql 
  6. binlog-ignore-db=test 
  7. binlog-ignore-db=information_schema 
  8. binlog-ignore-db=performance_schema 
  9. replicate-ignore-db=mysql 
  10. replicate-ignore-db=test 
  11. replicate-ignore-db=information_schema 
  12. replicate-ignore-db=performance_schema 
  13. master-connect-retry=10 

 

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

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

  重啟 MySQL.

  Server A:

 

  1. mysql -hserver_b -uuserx -pxxxxx 

  Server B:

 

  1. mysql -hserver_a -uuserx -pxxxxx 

  6. 導(dǎo)數(shù)據(jù)

  這一步是手工將兩臺(tái)服務(wù)器數(shù)據(jù)庫(kù)(基準(zhǔn)數(shù)據(jù))同步.

  Server A:

 

  1. mysqldump -uroot -p --databases db1 > a_dbdump.sql 
  2. scp a_dbdump.sql test@server_b:~ 

 

  Server B:

 

  1. mysqldump -uroot -p --databases db2 > b_dbdump.sql 
  2. scp b_dbdump.sql test@server_a:~ 

 

  Server A:

 

  1. source b_dbdump.sql 

  Server B:

 

  1. source a_dbdump.sql 

  可以使用下面的命令, 來(lái)自動(dòng)導(dǎo)出基準(zhǔn)數(shù)據(jù)并記錄 log position:

 

  1. mysqldump --all-databases --master-data > dbdump.db 

  這個(gè)命令會(huì)自動(dòng)生成 CHANGE MASTER TO 語(yǔ)句, 

  7. 啟動(dòng) Slave 線程

  Server A:

 

  1. FLUSH TABLES; 
  2. show master status; 

 

  會(huì)顯示這樣的信息.

 

  1. *************************** 1. row *************************** 
  2.             File: mysql-bin.000001 
  3.         Position: 106 
  4.     Binlog_Do_DB:  
  5. Binlog_Ignore_DB: mysql,test,information_schema,performance_schema 
  6. 1 row in set (0.00 sec) 

 

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

  Server B:

 

  1. CHANGE MASTER TO MASTER_HOST='server_a'
  2. CHANGE MASTER TO MASTER_USER='userx'
  3. CHANGE MASTER TO MASTER_PASSWORD='xxxxx'
  4. CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=106; 
  5. start slave; 
  6. show slave status\G 

 

  同樣的, 在 Server A 上也啟動(dòng)同步 Slave 進(jìn)程.

  因?yàn)槲覀兇_保了沒有數(shù)據(jù)庫(kù)寫操作, 所以不需要 FLUSH TABLES WITH READ LOCK; 如果無(wú)法確保, 那就需要使用前面提到的導(dǎo)數(shù)據(jù)方法.

  8. 驗(yàn)證

  在不同的數(shù)據(jù)庫(kù)上執(zhí)行一些更新數(shù)據(jù)的操作, 看看數(shù)據(jù)是否同步過去了.

  9. 完成

  恢復(fù) crontab 任務(wù)

  修改 nginx, 撤下維護(hù)網(wǎng)頁(yè), 恢復(fù)服務(wù)

  如果你有什么問題, 或者發(fā)現(xiàn)里這些步驟的不足, 歡迎評(píng)論!

  取消主從同步

 

  1. reset slave; 

  相關(guān)命令

 

  1. # 列出 binlog 文件列表 
  2. show binary logs; 
  3.  
  4. # 查看 binlog 內(nèi)容 
  5. show binlog events in 'mysql-bin.000002' limit 10; 
  6.  
  7. # 存有 slave 同步狀態(tài)的文件(master.info) 
  8. cat /var/lib/mysql/master.info 

 

  變更master的IP時(shí), 必須根據(jù)master.info里的信息, 同時(shí)變更LOGFILE信息:

 

  1. CHANGE MASTER TO MASTER_HOST='1.2.3.4'
  2. CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.xxx', MASTER_LOG_POS=; 

 

責(zé)任編輯:honglu 來(lái)源: idea's blog
相關(guān)推薦

2021-10-26 08:00:00

數(shù)據(jù)庫(kù)架構(gòu)技術(shù)

2017-05-25 10:11:46

數(shù)據(jù)庫(kù)令牌節(jié)點(diǎn)

2011-04-14 11:09:14

MySQL數(shù)據(jù)庫(kù)

2011-02-28 15:45:12

2011-03-24 14:59:42

2011-03-07 09:26:37

2019-10-12 16:15:13

MySQL數(shù)據(jù)庫(kù)多實(shí)例

2017-10-25 15:27:52

MySQL數(shù)據(jù)庫(kù)超時(shí)設(shè)置

2016-12-21 16:12:12

2025-04-28 08:35:07

2024-12-02 12:23:25

2010-06-09 10:47:36

MySQL數(shù)據(jù)庫(kù)集群

2009-06-16 09:25:31

JBoss配置

2009-06-16 10:55:23

MySQL數(shù)據(jù)庫(kù)

2010-05-26 18:16:31

MySQL數(shù)據(jù)庫(kù)安裝

2025-04-22 09:31:52

2011-03-30 10:15:14

Mysql數(shù)據(jù)庫(kù)服務(wù)器

2009-07-20 13:31:50

Ruby on Rai

2011-03-03 17:56:52

MySQL數(shù)據(jù)庫(kù)優(yōu)化

2010-04-19 16:01:54

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 在线中文字幕av | av中文在线播放 | 国产成人一区二区三区久久久 | 国产精品一区一区 | 黄色免费网址大全 | 日本精品999 | 天堂素人约啪 | 99精品视频一区二区三区 | 亚洲欧美激情视频 | av在线黄 | 久久精品国产久精国产 | 中文字幕福利 | 亚洲综合日韩精品欧美综合区 | 国产精品欧美一区二区 | 久久国 | 区一区二区三在线观看 | 一区二区国产精品 | 国产精品久久9 | 国产在线观看一区 | 日韩一区二区三区在线视频 | 毛片久久久 | 色爱综合网 | 久久久123 | 成人国产在线观看 | 日韩在线免费视频 | 天天操天天射综合网 | 国产精品黄 | 99精品久久久久 | 国产在线精品一区二区三区 | av大片在线观看 | 亚洲精品视频在线播放 | 久久69精品久久久久久久电影好 | 亚洲经典一区 | 手机av在线 | 欧美亚洲日本 | 欧美久久精品一级c片 | 人人看人人射 | 亚洲免费视频播放 | 综合伊人| 蜜臀久久99精品久久久久久宅男 | 成人精品一区二区户外勾搭野战 |