MySQL 数据库双主改造实例
发布:smiling 来源: PHP粉丝网 添加日期:2015-04-16 15:42:35 浏览: 评论:0
下面小编一起为各位介绍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:
- NT REPLICATION SLAVE ON *.* TO 'userx'@'server_b' IDENTIFIED BY 'xxxxx'; --phpfensi.com
- Server B:
- NT 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:
- ql -hserver_b -uuserx -pxxxxx
- Server B:
- ql -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,撤下维护网页,恢复服务.
Tags: MySQL 数据库 MySQL双主改造
相关文章
- ·怎样使MySQL安全以对抗解密高手(2013-11-11)
- ·MYSQL用户root密码为弱口令的攻击(2013-11-11)
- ·Mysql数据库的安全配置、实用技巧(2013-11-11)
- ·Mssql和Mysql的安全性分析(2013-11-11)
- ·MySQL安全问题的一点心得(2013-11-11)
- ·PHP常用MySql操作(2013-11-13)
- ·MySQL数据库下载漏洞攻击技术(2013-11-14)
- ·MySQL3.23.31之前版本的安全漏洞(2013-11-14)
- ·通过Mysql的语句生成后门木马的方法(2013-11-14)
- ·MySQL服务器内部安全数据目录访问(2013-11-14)
- ·MySQL数据库中的安全解决方案(2013-11-14)
- ·如何保护MySQL 中的重要数据(2013-11-14)
- ·为你的MySQL数据库加铸23道安全门(2013-11-14)
- ·Mysql的Root密码遗忘的解决办法(2013-11-14)
- ·如何开启MySQL的远程帐号(2013-11-14)
- ·我的Mysql碰到了 1067 错误(2013-11-27)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)