MySQL 5.7.9的多源复制

来源:互联网 发布:java byte数组转long 编辑:程序博客网 时间:2024/05/16 05:24

什么是多源复制?

首先,我们需要清楚 multi-master multi-source 复制不是一样的.Multi-Master 复制通常是环形复制,你可以在任意主机上将数据复制给其他主机。



Multi-source 是不同的. MySQL在这个新版本中修复了一个复制限制 , 这限制是一个从站只能有一个主站.这是一个在我们设计复制环境中的限制因素,也有一些极客使它正常工作了。但是现在有一个官方的解决办法了。所以。简单的说, Multi-Source意味着一个从站能有一个以上主站. 现在, 像下图一样的复制环境是可能的:


这将帮助我们创建一些复制的层次结构,这在过去是不可能的。 举个例子,你可以将一个从站放在你的办公室里。在办公室里从所有主站中复制数据传播到世界各地。

它是怎么工作的呢?

现在我们有了通信渠道的概念,每一个通信渠道都是一个从服务器从主服务器获得2进制日志的链接。这意味着每个通信渠道都得有一个IO_THREAD.我们需要运行不同的 “CHANGE MASTER” 命令, 对于每一个主服务器。我们需要用到“FORCHANNEL”这个参数来提供通信链接的名字。
CHANGE MASTER MASTER_HOST='something',MASTER_USER=... FORCHANNEL="name_of_channel";

很容易.有一个单一的先决条件。从服务器需要在mysql5.6上配置安全功能,这意味着信息通常包含在主服务器上。信息或日志应该在一个表中,让我们开始配置吧

来个例子!

首先,我们在从服务器上实现事故安全功能。
master_info_repository=TABLE;
relay_log_info_repository=TABLE;

让后重启从服务器。我们可以开始创建通信渠道,用 “master1″ 和“master2″这两个名字:
slave > change master tomaster_host="127.0.0.1", master_port=12047,master_user="msandbox",master_password="msandbox" forchannel="master1";
slave > change master tomaster_host="127.0.0.1", master_port=12048,master_user="msandbox",master_password="msandbox" forchannel="master2";

按照所设定的通信名字启动从服务器。
slave > start slave forchannel="master1";
slave > start slave forchannel="master2";

slave > SHOW SLAVE STATUS FORCHANNEL "master1"\G
*************************** 1. row***************************
               Slave_IO_State:Waiting for master to sendevent
                  Master_Host:127.0.0.1
                  Master_User:msandbox
                  Master_Port:12047
                Connect_Retry:60
              Master_Log_File:mysql-bin.000002
          Read_Master_Log_Pos:232
               Relay_Log_File:squeeze-relay-bin-master1.000003
                Relay_Log_Pos:395
        Relay_Master_Log_File:mysql-bin.000002
             Slave_IO_Running:Yes
            Slave_SQL_Running:Yes
[...]

我们也可以检查正在运行的  IO_THREAD 和 SQL_THREADS :
slave > SHOW PROCESSLIST;
+----+-------------+-----------------------------------------------------------------------------+
| Id| User       |State                                                                      |
+----+-------------+-----------------------------------------------------------------------------+
2 | system user |Waiting for master to sendevent                                           |
3 | system user | Slavehas read all relay log;waiting for the slave I/Othread to update it |
4 | system user |Waiting for master to sendevent                                           |
5 | system user | Slavehas read all relay log;waiting for the slave I/Othread to update it |
+----+-------------+-----------------------------------------------------------------------------+

结论

这个新的multi-source功能使在过去需要一些复杂操作创建的复制环境变得简单了。当然,你应用程序可以考虑这个新的特性设计和开发,使用 multi-master, multi-source都需要特别注意,不要把你的数据都弄乱了。

在每一个新的版本中,mysql的复制功能给我们更多的配置,性能和设计的可能性。所有这些新功能都可以结合起来。在你新(老)的功能中增加复制功能,你的复制环境会更加出色。举个例子:你可以配置 GTID 可以用 multi-threadedslave per schema或 intra-database.



转自:http://www.oschina.net/translate/mysql-5-7-multi-source-replication
0 0
原创粉丝点击