mysql传统主从、双主复制+keepalived配置步骤2
192.168.0.29 master1
192.168.0.30 master2
192.168.0.32 slave1
192.168.0.34 VIP
借鉴博客:http://www.cnblogs.com/xiaoboluo768/p/5135210.html
其中:master1和slave1是主从关系,master1和master2互为主从
一、先修改配置文件
服务器master1(192.168.0.29)配置如下
server-id = 1
log_slave_updates = 1
auto-increment-increment = 2
auto-increment-offset = 1
服务器master2(192.168.0.30)配置
server-id = 2
log_slave_updates = 1
auto-increment-increment = 2
auto-increment-offset = 2
服务器slave1(192.168.0.32) 配置:
server-id = 3
log_slave_updates = 1
三台服务器mysql都重启
shell > service mysqld restart
注:双主之间只有server-id不同和 auto-increment- offset不同
auto-increment-offset是用来设定数据库中自动增长的起点的,回为这两能服务器都设定了一次自动增长值2,所以它们的起点必须得不同,这样才能避免两台服务器数据同步时出现主键冲突
另:auto-increment-increment的值应设为整个结构中主库服务器的总数,本案例用到两台主库服务器,所以值设为2
二、同步数据
在master1上:
#先授权,这样导出的sql文件中就包含用户名和密码,如果你不需要同步系统库,那么,需要在从库change master之前,主从mysql实例都进行授权
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.0.%' IDENTIFIED BY '123456';
mysql > grant replication slave on *.* to repl@'127.0.0.1' identified by '123456';
mysql> flush privileges;
使用mysqldump导出所有数据库的数据备份,备份数据前先锁表,保证数据一致性
mysql> FLUSH TABLES WITH READ LOCK;
开启另外一个会话终端执行数据备份:
shell > /usr/local/services/mysql/bin/mysqldump -uroot -p'xx' --opt --default-character-set=utf8 --triggers -R --hex-blob --single-transaction --no-autocommit --all-databases > all.sql
查看binlog位置,并记下这些信息,后边会用到:
mysql> show master status\G;
*************************** 1. row ***************************
File: mysql-bin.000004
Position: 107
Binlog_Do_DB:
Binlog_Ignore_DB:
1 row in set (0.00 sec)
解表锁:
mysql> UNLOCK TABLES;
把备份文件传送到master2和slave1上:
shell > scp all.sql 192.168.0.30:/tmp
shell > scp all.sql 192.168.0.32:/tmp
导出数据时也可以不手动加锁解锁,mysqldump加一个参数:--master-data=2,该参数会把change master 语句加到all.sql文件中,以注释的形式写入,包含master_log_file和master_log_pos,复制出来带上主库IP、用户名和密码(master_host,master_user,master_password)待从库导入数据后,即可在从库上执行change master语句。
grep '\-\- CHANGE MASTER' all.sql
三、互告bin-log信息
在master2中导入all.sql文件,并执行change master语句:
shell > /usr/local/services/mysql/bin/mysql -uroot -p'xx' < /tmp/all.sql
mysql> change master to master_host='192.168.0.29',master_user='repl',master_password='123456',master_log_file='mysql-bin.000004',master_log_pos=107;
在slave1上执行下面的操作:
导入all.sql文件,并执行change master语句:
shell > /usr/local/services/mysql/bin/mysql -uroot -p'xx' < /tmp/all.sql
mysql> change master to master_host='192.168.0.29',master_user='repl',master_password='123456',master_log_file='mysql-bin.000004',master_log_pos=107;
在master2上面查看binlog位置:
先执行如下:
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.0.%' IDENTIFIED BY '123456';
show master status\G;
*************************** 1. row ***************************
File: mysql-bin.000003
Position: 509270
Binlog_Do_DB:
Binlog_Ignore_DB:
1 row in set (0.00 sec)
在master1上执行change master
mysql> change master to master_host='192.168.0.30',master_user='repl',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=509270;
四、在三服务器都执行以下命令
mysql> start slave;
五、查看状态
mysql> show slave status\G
master1、master2 、slave1 全部状态如下:
show slave status\G;
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com