MySQL数据库主从及主主复制配置演示(2)

  4.如果主数据库不是新建立的,而是使用过一段时间,且里面已经有不少数据的情况下,需要先把主服务器数据导出,再导入到从服务器,然后根据上面的步骤进行主从复制,这里将不再演示。

  导出数据库命令参考:mysqldump --all-databases --lock-all-tables --master-data=2 > name.sql

三、半同步复制

  1.什么是半同步复制?

    因为开启这个功能之后,主服务器只等待多个从服务器中的指定的一台从服务器复制成功,然后才进行其他写操作,使这个从服务器和主服务器上的数据完全同步,而并不管其他的从服务器。这在一定程度上就保证了我们数据的安全性。这个功能需要打由google贡献的补丁,它是以插件的形式存在的。补丁存放的位置在:/usr/local/mysql/lib/plugin/

  2.主服务器打补丁:

/usr/local/mysql/bin/mysql
---------------------------------------------
INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';
SHOW GLOBAL VARIABLES LIKE '%semi%';        //查看状态

MySQL数据库主从及主主复制配置演示

  3.主服务器修改配置:

SET GLOBAL rpl_semi_sync_master_enabled=1;
SET GLOBAL rpl_semi_sync_master_timeout=1000;

  4.从服务器打补丁:

/usr/local/mysql/bin/mysql
---------------------------------------------
INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
SHOW GLOBAL VARIABLES LIKE '%semi%';

MySQL数据库主从及主主复制配置演示

  5.从服务器修改配置:

SET GLOBAL rpl_semi_sync_slave_enabled=1;
STOP SLAVE;
START SLAVE;

  6.主服务器查看状态:

SHOW GLOBAL STATUS LIKE '%semi%';

MySQL数据库主从及主主复制配置演示

四、主主复制

  1.由于刚才做了许多操作,为了不影响之后的实验,我们先将数据库进行重置:

service mysqld stop
rm -rf /mydata/data/*                                                                    //删除数据库文件
/usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/mydata/data/        //初始化mysql

  2.修改my.cnf:

    19.43上:

vim /etc/my.cnf
-------------------------------------------
[mysqld]
server-id=1
log-bin=/mydata/data/mysql1-bin              //开启二进制日志
relay_log=/mydata/data/relay-log              //开始中继日志
auto-increment-increment = 2                  //每次增长的数值
auto-increment-offset = 1                    //开始的数值

    19.48上:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/f7c2d27fcea7eed2eced9dbf7d3a0ac2.html