mysql的主主同步實際上就是兩臺服務器之間互爲主從,因此基本原理和mysql主從是同樣的,因此能夠先按個人這篇博客mysql主從同步配置 配置主從同步後, 再按如下步驟配置反向的主從同步便可,具體以下:mysql
登陸原來的從機,即Ip爲192.168.0.105的服務器sql
在原來的從機上本置一個用於同步的用戶,以下:數據庫
GRANT REPLICATION SLAVE ON *.* to 'mysync'@'192.168.0.101' identified by 'q123456';
2. 鎖定數據庫,以下
服務器
mysql> flush tables with read lock; Query OK, 0 rows affected (0.03 sec)
3. 查看主機的當前狀態(由於這時候把原來的從機看成了主機):ide
mysql> show master status; +------------------+----------+--------------+------------------+--------------- ----+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_ Set | +------------------+----------+--------------+------------------+--------------- ----+ | mysql-bin.000003 | 341 | | | | +------------------+----------+--------------+------------------+--------------- ----+ 1 row in set (0.00 sec)
4. 記錄下File和Position兩個字段的值,下面配置另外一臺服務器的主機時須要用到spa
5. 解鎖數據庫.net
unlock tables; Query OK, 0 rows affected (0.00 sec)
登陸原來的主機,即Ip爲192.168.0.105的服務器code
1. 配置對應主服務器的信息(這時對應的主服務器爲原來的從機即ip爲192.168.0.101的服務器)blog
mysql> change master to master_host='192.168.0.105',master_user='mysync',master_ password='q123456', master_log_file='mysql-bin.000003',master_log_pos=341; Query OK, 0 rows affected, 2 warnings (0.91 sec)
2. 啓動從屬進程
進程
mysql> start slave; Query OK, 0 rows affected (0.09 sec) mysql> start slave; Query OK, 0 rows affected (0.09 sec) mysql> show slave status\G *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.0.105 Master_User: mysync Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin.000003 Read_Master_Log_Pos: 341 Relay_Log_File: user-PC-relay-bin.000002 Relay_Log_Pos: 283 Relay_Master_Log_File: mysql-bin.000003 Slave_IO_Running: Yes Slave_SQL_Running: Yes
最後使用show slave status命令查看Slave_IO_Running和Slave_SQL_RunningG兩個字段的值都爲YES即表示配置成功。
備註:
最後貌似還要在原來的從機如今主機上再次配置對應主機的信息才行,即從新執行如下命令
mysql> change master to master_host='192.168.0.101',master_user='mysync',master_ password='q123456', master_log_file='mysql-bin.000001',master_log_pos=341; Query OK, 0 rows affected, 2 warnings (0.91 sec)
而後還須要再次重啓slave進程才行,不然在原來主機上的操做不會同步到從機上來。