设为首页 收藏本站
查看: 1027|回复: 0

[经验分享] mysql传统主从、双主复制+keepalived配置步骤

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-1-22 08:42:38 | 显示全部楼层 |阅读模式
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

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-331792-1-1.html 上篇帖子: mysql备份 下篇帖子: mysql多源复制
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表