在主主复制结构中,两台服务器的任何一台上面的数据库存发生了改变都会同步到另一台服务器上,这样两台服务器互为主从,并且都能向外提供服务。配置的时候需要注意:主键重复,server-id不能重复。 1.新建数据库 Ubuntu16.04,开启两个虚拟机。 配置前,两个mysql分别新建一个数据库,保证的test数据库的数据一致 create database test default character set utf8 default collate utf8_general_ci; 2.修改配置文件 vim /etc/mysql/mysql.conf.d/mysqld.cnf 服务器A(192.168.8.129)配置如下 bind-address = 0.0.0.0 log_bin = /var/log/mysql/mysql-bin.log #开启二进制日志 server-id = 1 #任意自然数n,只要保证两台MySQL主机不重复即可 expire-logs-days = 100 replicate-do-db = test #要同步的数据库,默认所有库 binlog-ignore-db = mysql #忽略mysql库 binlog-ignore-db = information_schema #忽略information_schema库 auto-increment-increment = 2 #步进值,有n台主MySQL就填n auto-increment-offset = 1 #起始值。第n台主MySQL,此时为第1主MySQL
服务器B(192.168.8.131)配置 bind-address = 0.0.0.0 log_bin = /var/log/mysql/mysql-bin.log server-id = 2 expire-logs-days = 100 replicate-do-db = test binlog-ignore-db = mysql binlog-ignore-db = information_schema auto-increment-increment = 2 auto-increment-offset = 2 #起始值,第2台主MySQL 二者只有server-id不同和 auto-increment- offset不同 auto-increment-offset是用来设定数据库中自动增长的起点的,两个服务器都设定了一次自动增长值2,所以它们的起点必须得不同,这样才能避免两台服务器数据同步时出现主键冲突 replicate-do-db 指定同步的数据库,我们只在两台服务器间同步test数据库。auto-increment-increment的值应设为整个结构中服务器的总数,本例用到两台服务器,所以值设为2 3.重启mysql服务 /etc/init.d/mysql restart 4.创建共享用户 创建一个可以在另一台主机上登录的MySQL用户repl 看是否有mysql中是否有repl这个用户 use mysql; select user from user;
若没有的话,新建用户 create user 'repl'@'%' IDENTIFIED BY 'passwd'; grant replication slave on . to 'repl'@'%'; flush privileges; 查看repl用户的权限 show grants for 'repl'@'%';
9.测试是否同步成功 在A上 create table test_user (id int NOT NULL AUTO_INCREMENT PRIMARY KEY,createtime datetime NOT NULL DEFAULT CURRENT_TIMESTAMP); 在B上可以看到新增了一个表
在B上 insert into test_user set id=1; 在A上可以看到test_user表中新增了一条记录。