mysql5.7主從同步配置

1. 準備工作

(本文永久地址:http://woymk.blog.51cto.com/10000269/1922438

配置環境:centos6.9,mysql5.7

先安裝、配置好兩臺MySQL服務器

主服務器IP:192.168.1.1

從服務器IP:192.168.1.2

mysql的安裝請參考之前的文章:

LAMP環境搭建(centos6.9+apache2.4+mysql5.7+php7.1)



2. 配置主(master)
vi /etc/my.cnf
修改或添加下面這幾行:
server-id=1

log-bin=mysql-bin # 啓用二進制日誌

兩個可選參數(2選1):
binlog-do-db=db1,db2 #需要同步的庫
binlog-ignore-db=db1,db2 #忽略不同步的庫

保存後重啓

/etc/init.d/mysqld restart

運行mysql客戶端
mysql -uroot -p

創建同步賬號

grant replication slave on *.* to 'repl'@'192.168.1.2' identified by '1234';
flush privileges;

鎖表,不讓數據寫入

flush tables with read lock;
show master status;

wKioL1kMHxHDebpBAAAQHbOTN3A255.png-wh_50

記錄下二進制日誌文件名和位置


備份數據庫

在master上執行
mysqldump -uroot -p db1 > back.sql;

把備份好的數據拷貝到從服務器

scp back.sql 192.168.1.2:~


3. 配置從(slave)

vi /etc/my.cnf
修改或增加:
server-id=2 #這個數值不能和主一樣
可選參數(2選1,這兩個參數設置成和主一樣):
replicate-do-db=db1,db2
replicate-ignore-db=db1,db2

保存後重啓

/etc/init.d/mysqld restart

把主服務器備份的數據導入從服務器

在slave上執行
[root@slave ~]# mysqldump -uroot -p db1 < back.sql

運行mysql客戶端

mysql -uroot -p

執行以下命令
stop slave; (根據mysql官方手冊的說明,5.5之前是slave stop,5.6之後改爲stop slave)
change master to master_host='192.168.1.1', master_user='repl', master_password='1234',master_log_file='mysql-bin.000001', master_log_pos=2757;

(master_log_file和master_log_pos填上剛纔記錄下的二進制日誌文件名和位置)

start slave;

查看從服務器的狀態:

show slave status\G

wKioL1kN-QuAzmCyAAA7qNrPyPo445.png-wh_50


完成後取消主服務器數據庫的鎖定

在主上執行
mysql> unlock tables;


4. 驗證主從複製效果

在主服務器上創建數據庫test_db

create database test_db;

在主服務器上創建表test_tb

use test_db;

create table test_tb(id int(3),name char(10));

寫入一行記錄

insert into test_tb values(001,"test");


在從服務器上查看

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| discuz             |
| mysql              |
| performance_schema |
| sys                |
| test_db            |
| www                |
+--------------------+

7 rows in set (0.00 sec)

數據庫test_db已經自動創建了

mysql> select * from test_db.test_tb;
+------+------+
| id   | name |
+------+------+
|    1 | test |
+------+------+
1 row in set (0.00 sec)

表裏的數據也已經自動複製過來了,說明主從同步配置成功。




配置mysql主從時,如果顯示下列錯誤:

Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.

這是因爲mysql是克隆過來的,或者拷貝整個data目錄時把auto.cnf文件也拷貝過來了,導致主從mysql uuid相同, Slave_IO無法啓動。

解決辦法:修改mysql data 目錄下auto.cnf 文件中uuid的值,或者刪除auto.cnf文件後重啓mysql服務讓它自動生成新的uuid值。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章