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

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

[复制链接]

尚未签到

发表于 2018-12-31 11:48:52 | 显示全部楼层 |阅读模式
  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-657936-1-1.html 上篇帖子: Keepalived+Nginx实现前端负载均衡的高可用 下篇帖子: 用haproxy搭建web群集并由keepalived 实现双机热备
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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