MySQL 数据库双主配置

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

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

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

  如果想增加一个从库, 可参考此篇: MySQL 在线增加从库.

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

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

  另外, 还要停止 crontab 任务.

  2. 备份数据库

  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 

 

  把线上数据库备份到本地

 

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

 

  3. 新建数据库同步账号

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

  重启 MySQL.

  Server A:

 

  1. mysql -hserver_b -uuserx -pxxxxx 

  Server B:

 

  1. mysql -hserver_a -uuserx -pxxxxx 

  6. 导数据

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

  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 

  可以使用下面的命令, 来自动导出基准数据并记录 log position:

 

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

  这个命令会自动生成 CHANGE MASTER TO 语句, 

  7. 启动 Slave 线程

  Server A:

 

  1. FLUSH TABLES; 
  2. show master status; 

 

  会显示这样的信息.

 

  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, 这时 binlog 的当前位置, 因为 Slave 要从这个位置开始同步数据.

  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 上也启动同步 Slave 进程.

  因为我们确保了没有数据库写操作, 所以不需要 FLUSH TABLES WITH READ LOCK; 如果无法确保, 那就需要使用前面提到的导数据方法.

  8. 验证

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

  9. 完成

  恢复 crontab 任务

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

  如果你有什么问题, 或者发现里这些步骤的不足, 欢迎评论!

  取消主从同步

 

  1. reset slave; 

  相关命令

 

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

 

  变更master的IP时, 必须根据master.info里的信息, 同时变更LOGFILE信息:

 

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

 

责任编辑:honglu 来源: idea's blog
相关推荐

2021-10-26 08:00:00

数据库架构技术

2017-05-25 10:11:46

数据库令牌节点

2011-02-28 15:45:12

2011-04-14 11:09:14

MySQL数据库

2017-10-25 15:27:52

MySQL数据库超时设置

2011-03-07 09:26:37

2019-10-12 16:15:13

MySQL数据库多实例

2011-03-24 14:59:42

2010-05-26 18:16:31

MySQL数据库安装

2009-06-16 10:55:23

MySQL数据库

2009-06-16 09:25:31

JBoss配置

2016-12-21 16:12:12

2010-06-09 10:47:36

MySQL数据库集群

2009-07-20 13:31:50

Ruby on Rai

2011-03-30 10:15:14

Mysql数据库服务器

2011-03-03 17:56:52

MySQL数据库优化

2019-09-05 09:17:37

MySQL数据库线程

2010-04-19 16:01:54

2012-09-25 09:19:26

Spring数据库双数据库

2011-05-13 09:42:21

点赞
收藏

51CTO技术栈公众号