首页 > 数据库 > MySQL > 正文

MySQL 数据库双主改造实例

2024-07-24 12:39:28
字体:
来源:转载
供稿:网友

下面小编一起为各位介绍MySQL 数据库双主改造实例,如果有兴趣的可以看看,搭配方法非常的简单.

对于使用中的已有了一些数据库的 MySQL,如何改造成双主呢? 这里写一篇文章,详细记录操作步骤,听取各位的意见.

这里假设有两台服务器:A 和 B. 要让他们互为主,但实际使用时,不同的服务器只服务不同的 db,避免出现数据冲突.

1.修改 NGINX 配置,挂维护页

这一步很重要.你需要告诉你的用户,你的网站在维护,同时要确保不会再出现数据库写操作,另外,还要停止 crontab 任务.

2.备份数据库

  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 

把线上数据库备份到本地

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

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

3.新建数据库同步账号

  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.导数据

这一步是手工将两台服务器数据库(基准数据)同步.

  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, 测试同步账号可用

重启 MySQL.

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

7.启动 SLAVE 线程

  1.    Server A: 
  2. FLUSH TABLES; 
  3. show master status; 
  4.    会显示这样的信息. 
  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, 这时 binlog 的当前位置,因为 Slave 要从这个位置开始同步数据.

  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 上也启动同步 Slave 进程,因为我们确保了没有数据库写操作, 所以不需要 FLUSH TABLES WITH READ LOCK;.

8. 验证

在不同的数据库上执行一些更新数据的操作, 看看数据是否同步过去了.

9.完成

恢复 crontab 任务,修改 nginx,撤下维护网页,恢复服务.

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表