MySQL主主(雙主)數據同步
阿新 • • 發佈:2018-04-05
主主同步 雙主同步 mysql主主同步 mysql雙主同步 數據目錄:/data/mysql/
A與B機器都安裝好了MySQL,數據庫與表都提前同步好;
1. 兩臺mysql都可以讀寫,互為主備,默認只是用一臺(masterA)負責數據的寫入,另一臺(masterB)備用;
2. masterA是masterB的主庫,masterB又是masterA的主庫,他們互為主從;
不足之處:
1. masterB可能處於抑制空閑狀態(可以用他當從庫,負責部分查詢);
2. 主庫後面提供服務的從庫要等masterB先同步完了數據後才能去masterB上去同步數據,肯能會造成一定程度的同步延遲;
搭建環境
系統:CentOS7
數據庫版本:5.6.36
masterA地址:192.168.188.2
masterB地址:192.168.188.3
安裝目錄:/usr/local/mysql/
A與B機器都安裝好了MySQL,數據庫與表都提前同步好;
防火墻配置
iptables
添加mysql同學端口(默認3306)
vim /etc/sysconfig/iptables //編輯iptables文件,也可以用iptables命令來添加,不過要保存命令
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT //添加允許3306端口通過
service iptables restart //重啟iptables服務
關閉selinux
vim /etc/selinux/config //編輯SELinux配置文件 SELINUX=disabled //修改值為disabled為關閉
服務器設置
masterA設置(192.168.188.2)
vim /etc/my.cnf //編輯my.cnf文件
server-id=2 //增加server-id為2,一般為自己ip
log_bin=test01 //設置log_bin名為test01
/etc/init.d/mysqld restart //重啟mysql服務
mysql -uroot -p123456 //登錄mysql,不要照抄,-u後面是賬號,-p後面是密碼 grant replication slave on *.* to ‘repl‘@‘192.168.188.3‘ identified by ‘123456‘; //創建mysql賬號repl,只容許指定ip訪問,也可以指定ip範圍192.168.188.%,其中%為通配符,表示所有; flush privileges; //刷新授權表信息 flush tables with read lock; //鎖定數據庫表暫時無法寫服務; show master status; //查看binlog文件值與pos值 stop slave; //關閉同步
masterB設置(192.168.188.3)
vim /etc/my.cnf
server-id=3 //增加server-id為3,一般為自己ip
log_bin=test02 //設置log_bin名為test02
/etc/init.d/mysqld restart //重啟mysql服務
mysql -uroot -p123456 //登錄mysql
grant replication slave on *.* to ‘repl‘@‘192.168.188.2‘ identified by ‘123456‘; //創建用戶,允許192.168.188.2登錄本機器
flush privileges; //刷新授權表
stop slave; //關閉同步
show master status; //查看binlog文件值與pos值
change master to master_host=‘192.168.188.2‘, master_user=‘repl‘, master_password=‘123456‘, master_log_file=‘test01.000001‘, master_log_pos=664383; //這裏註意log_file與pos值都要對應對應A的show master status;值
start slave; //開啟同步
masterA設置
change master to master_host=‘192.168.188.3‘, master_user=‘repl‘, master_password=‘123456‘, master_log_file=‘test02.000001‘, master_log_pos=664343; //這裏log_file與pos值寫的必須是B上show master status;的值
start slave; //開啟同步
unlock tables; //解鎖寫
測試主主
在A的test數據庫下建立t1表,B上查詢後有t1表,證明B能同步A修改的數據;
在B的test數據庫下建立t2表,A上查詢,有t2表,證明A能同步到B修改後的數據;
masterA設置
mysql -uroot -p123456 //登錄mysql
mysql> use test; //切換到數據庫test
mysql> show tables; //查看當前數據庫的所有表,這裏沒有一個表
Empty set (0.00 sec)
mysql> create table t1(`id` int(4),`name` char(40)); //插入一個表t1
mysql> show tables; //查看當前數據庫的表
+----------------+
| Tables_in_test |
+----------------+
| t1 |
+----------------+
1 row in set (0.00 sec)
masterB
mysql -uroot -p123456 //登錄mysql
use test; //切換到數據庫test
mysql> show tables; //查詢同步到數據庫test下出現了t1表,證明B能同步A的數據;
+----------------+
| Tables_in_test |
+----------------+
| t1 |
+----------------+
1 row in set (0.00 sec)
create table t2(`id` int(4),`name` char(40)); //新建一個t2表,如果A能同步到,就證明A能同步到B
切換masterA(省略了登錄與切換數據庫的命令)
mysql> show tables; //查詢A的test數據庫下所有的表
+----------------+
| Tables_in_test |
+----------------+
| t1 |
| t2 |
+----------------+
2 rows in set (0.00 sec)
MySQL主主(雙主)數據同步