MySQL双主配置的项目实践

 更新时间:2024年12月10日 10:00:14   作者:热干面先拌拌  
本文详细介绍了配置两台MySQL服务器之间的主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

1、配置的前置条件

  • 已知A服务器IP=192.168.0.11,B服务器IP=192.168.0.12
  • 建议使用相同版本的MySQL,若是小版本跨越一般是兼容的,如A的MySQL版本是5.7.1,B的MySQL版本是5.7.2;
  • 配置前需要保证两个数据库的数据一致,建议将A数据库同步到B数据库,以保证配置前A、B两台数据库的数据是一致的;
  • 确保2台数据库的网络端口是互通的,如:3306;
  • 配置期间不能有新数据的写入;

2、配置 

2.1 配置B服务器MySQL同步A服务器MySQL数据

2.1.1  修改A服务器的MySQL配置文件my.cnf,添加以下内容

[mysqld]
#master A slave config
#主机A的server id,需要和主机B的不一致
server-id=1
#二进制日志文件名
log-bin=master-a-bin
#二进制日志格式
binlog-format=ROW
#设置日志最大为1G
max_binlog_size=1024M
#设置binlog文件最大保留天数30天
expire_logs_days=30
#数据库宕机恢复后,自动同步缺少的数据
relay_log=mysql-relay-bin
relay_log_recovery=1
#设置自增id的初始值为1,每次增量为2
auto_increment_offset=1
auto_increment_increment=2
#开启gtid
gtid_mode=ON
enforce_gtid_consistency=1
#需要同步的数据库,如test1,test2,根据实际情况配置
binlog-do-db=test1
binlog-do-db=test2
#不要同步的数据库
binlog-ignore-db=mysql,information_schema,performance_schema,sys
#不要同步的表
#replicate-ignore-table=库名.表名

配置完成后,保存并重启一下MySQL

2.1.2 登录A服务器MySQL,创建B的数据同步账号

同步账号:repl_b,同步密码:123456,具体命令步骤如下

mysql> grant replication slave on *.* to '同步账号'@'主机B的IP' identified by '同步密码';
#登录A服务器MySQL,创建B的数据同步账号
mysql> flush privileges;
#刷新权限
mysql> reset master;
#重置master信息
#说明:同步开始前,不要有数据写入,否则影响bin-log日志文件
mysql> flush tables with read lock;
#锁表命令,在同步配置完成后再使用解锁表命令:unlock tables;
mysql> show master status;
#查看并记录好当前bin-log的文件名和位置,记录bing-log文件名:master-a-bin.000001,日志位置:154

2.1.3 登录B服务器修改MySQL的配置文件my.cnf,设置A为B的master,添加以下

#master B slave config
#主机B的server id,与主机A的id不一致
server-id=2
#二进制日志文件名
log-bin=master-b-bin
#二进制日志格式
binlog-format=ROW
#设置日志最大为1G
max_binlog_size=1024M
#设置binlog文件最大保留天数30天
expire_logs_days=30
#数据库宕机恢复后,自动同步缺少的数据
relay_log=mysql-relay-bin
relay_log_recovery=1
#设置自增id的初始值为1,每次增量为2
auto_increment_offset=2
auto_increment_increment=2
#开启gtid
gtid_mode=ON
enforce_gtid_consistency=1
#需要同步的数据库,如test1,test2,根据实际情况配置
binlog-do-db=test1
binlog-do-db=test2
#不要同步的数据库
binlog-ignore-db=mysql,information_schema,performance_schema,sys
#不要同步的表 
#replicate-ignore-table=库名.表名

配置完成后,保存并重启以下MySQL 

登录主机B的MySQL,设置A为B的master

PS:如果开启了全局事务id(gtid_mode=ON),那么可以不用指定master_log_pos参数,可去掉此参数

#备份好需要同步的数据库,把备份好的数据库导入到主机B上
#登录主机B的mysql,设置A为B的master
#停止B的slave
mysql> stop slave;
#设置B的master的为A,通过repl_b同步A的数据
mysql> change master to master_host='主机A的IP',master_user='同步账号',master_password='同步密码',master_log_file='bing-log文件名',master_log_pos=日志位置;
#开启B的slave
mysql> start slave;
#确定B的slave是否同步成功
mysql> show slave status\G;
#查看输出结果中Slave_IO_Running和Slave_SQL_Running都为YES时,表示成功

到这步已经完成了B服务器MySQL同步A服务器数据,下面再进行设置A同步B服务器的MySQL

2.2 配置A服务器MySQL同步B服务器MySQL数据

2.2.1 登录B服务器的MySQL,创建A服务器的MySQL同步账号,同步账号:repl_a,密码:123456

#登录B的mysql
mysql> grant replication slave on *.* to '同步账号'@'主机A的IP' identified by '同步密码';
mysql> flush privileges;
#说明:同步开始前,建议不要有数据写入,否则影响bin-log日志文件
#重置master信息
mysql> reset master;
#锁表命令,同步完成后使用解锁表命令:unlock tables
mysql> flush tables with read lock;
#查看并记录好当前bin-log的文件名和位置,记录bing-log文件名:master-b-bin.000001,日志位置:154
mysql> show master status;

2.2.2、登录A服务器MySQL,设置B为A的master

#登录A主机,停止slave
mysql> stop slave;
#设置A的master为B
mysql> change master to master_host='主机B的IP',master_user='同步账号',master_password='同步密码',master_log_file='master-b-mysql-bin.000001',master_log_pos=154;
#启动slave
mysql> start slave;
mysql> show slave status\G;
#查看输出结果中Slave_IO_Running和Slave_SQL_Running都为YES时,表示成功

3、解锁数据库表的锁定

在A服务器和B服务器的MySQL里面执行解锁命令:unlock tables

mysql> unlock tables;

4、进行数据库的读写同步测试

在A更改(插入、修改、删除)的数据会实时同步至B的数据库,同样B更改数据也会实时同步至A

到此这篇关于MySQL双主配置的项目实践的文章就介绍到这了,更多相关MySQL双主配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL数据库改名的三种实现方式

    MySQL数据库改名的三种实现方式

    这篇文章主要介绍了MySQL数据库改名的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • 利用ssh tunnel链接mysql服务器的方法

    利用ssh tunnel链接mysql服务器的方法

    这篇文章主要给大家介绍了利用ssh tunnel链接mysql服务器的方法,文中介绍的很详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • MySQL中Case When用法及说明

    MySQL中Case When用法及说明

    这篇文章主要介绍了MySQL中Case When用法及说明,具有很好的参考价值,希望对大家有所帮助。
    2022-12-12
  • 浅谈mysql的timestamp存在的时区问题

    浅谈mysql的timestamp存在的时区问题

    本文主要介绍了浅谈mysql的timestamp存在的时区问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • mysql视图之管理视图实例详解【增删改查操作】

    mysql视图之管理视图实例详解【增删改查操作】

    这篇文章主要介绍了mysql视图之管理视图,结合实例形式详细分析了mysql视图增删改查操作具体实现技巧与相关操作注意事项,需要的朋友可以参考下
    2019-12-12
  • MySQL5.7.21解压版安装详细教程图解

    MySQL5.7.21解压版安装详细教程图解

    对于小编来说安装系统软件是常干的事情,今天小编抽空给大家整理了MySQL5.7.21解压版安装详细教程图解,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-09-09
  • mysql的union和union all用法详解

    mysql的union和union all用法详解

    union 和 union all 的区别是,union 会自动压缩多个结果集合中的重复结果,而 union all 则将所有的结果全部显示出来,不管是不是重复,本文给大家介绍mysql的union和union all用法,感兴趣的朋友一起看看吧
    2023-08-08
  • 解决Can''t locate ExtUtils/MakeMaker.pm in @INC报错

    解决Can''t locate ExtUtils/MakeMaker.pm in @INC报错

    今天小编就为大家分享一篇关于解决Can't locate ExtUtils/MakeMaker.pm in @INC报错,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • Redis与MySQL的双写一致性问题

    Redis与MySQL的双写一致性问题

    这篇文章只要介绍了Redis与MySQL双写一致性,主要是指在使用缓存和数据库同时存储数据的场景下( 主要是存在高并发的情况),如何保证两者的数据一致性(内容相同或者尽可能接近),感兴趣的同学可以借鉴一下
    2023-03-03
  • 分享MYSQL插入数据时忽略重复数据的方法

    分享MYSQL插入数据时忽略重复数据的方法

    当程序中insert时,已存在的数据不插入,不存在的数据insert。在网上搜了下,可以使用存储过程或者是用NOT EXISTS 来判断是否存在
    2013-09-09

最新评论