MySQL 主主复制

发布于 2017-09-06 15:04:51

MySQL的主主复制就是两台 mysql 节点互为主从。搭建起来 mysql 主从,再来搭建主主复制就非常简单了。

 

视频链接:http://www.roncoo.com/course/view/658088f6e77541f5835b61800314083e 

 

在原来主从的基础上做如下操作:

 

1.开启原从节点的 binlog 日志

 

2.原从节点创建读取副本的用户

 

3.在原主节点中让 master 指向从节点

 

4.在原主节点执行 start slave 命令

 

以上步骤即可完成主主节点的配置

 

 

下面有一个问题需要解决,就是自增主键的问题,按照上面的做法,如果向两个节点中插入数据,一定会导致主键的重复,这里需要一个小的技巧

 

这里让第一台节点主键采用 1 3 5 7.。。的方式自增第二台节点采用 2,4,6,8 的方式递增这样就不会导致主键冲突了

auto_increment_increment=2
auto_increment_offset=1

 

在 MySQL5.7 中,不需要配置主键自增策略,每个库的操作都会让另外一个库递增

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
主主复制是指在两台 MySQL 服务器之间建立双向主从复制,使得两台服务器都可以作为主服务器和从服务器进行读写操作。以下是 MySQL 主主复制的配置部署步骤: 1. 首先,在两台服务器上安装 MySQL 数据库,并确保两台服务器的 MySQL 版本相同。 2. 配置两台服务器的 MySQL 配置文件 my.cnf,将 server-id 参数设置为不同的值,以便在复制时避免 ID 冲突。 3. 在两台服务器上创建用于主从复制的用户,并授予相应的权限。 4. 在第一台服务器上执行以下命令,创建用于复制的数据库和表,并添加一些测试数据: ``` CREATE DATABASE mydb; USE mydb; CREATE TABLE mytable (id INT NOT NULL AUTO_INCREMENT, name VARCHAR(50), PRIMARY KEY (id)); INSERT INTO mytable (name) VALUES ('John'), ('Mary'), ('Tom'); ``` 5. 在第一台服务器上执行以下命令,开启二进制日志记录(binary logging): ``` vi /etc/my.cnf # 添加以下配置 log-bin=mysql-bin server-id=1 ``` 6. 在第一台服务器上执行以下命令,重启 MySQL 服务,使配置生效: ``` service mysqld restart ``` 7. 在第二台服务器上执行以下命令,开启二进制日志记录(binary logging): ``` vi /etc/my.cnf # 添加以下配置 log-bin=mysql-bin server-id=2 ``` 8. 在第二台服务器上执行以下命令,重启 MySQL 服务,使配置生效: ``` service mysqld restart ``` 9. 在第二台服务器上执行以下命令,配置主服务器为第一台服务器: ``` CHANGE MASTER TO MASTER_HOST='first_mysql_host', MASTER_USER='replication_user', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107; ``` 其中,first_mysql_host 为第一台服务器的 IP 地址或主机名,replication_user 和 password 为在第一台服务器上创建的用于复制的用户和密码,mysql-bin.000001 为第一台服务器的二进制日志文件名,107 为二进制日志文件的偏移量。 10. 在第一台服务器上执行以下命令,配置主服务器为第二台服务器: ``` CHANGE MASTER TO MASTER_HOST='second_mysql_host', MASTER_USER='replication_user', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107; ``` 其中,second_mysql_host 为第二台服务器的 IP 地址或主机名,replication_user 和 password 为在第二台服务器上创建的用于复制的用户和密码,mysql-bin.000001 为第二台服务器的二进制日志文件名,107 为二进制日志文件的偏移量。 11. 在第一台服务器上执行以下命令,启动主从复制: ``` START SLAVE; ``` 12. 在第二台服务器上执行以下命令,启动主从复制: ``` START SLAVE; ``` 13. 验证主从复制是否正常工作,可以在两台服务器上执行以下命令: ``` SELECT * FROM mydb.mytable; ``` 如果输出结果相同,则说明主从复制已经成功配置部署。 以上就是 MySQL 主主复制的配置部署步骤。需要注意的是,在进行主主复制配置时,需要确保两台服务器的 MySQL 版本相同,并且需要注意防止 ID 冲突。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值