MySQL 5.7的安裝及主從複製(主從同步)

Franson發表於2018-03-30

1、master上開啟binlog日誌,配置如下

一般mysql配置檔案在目錄/etc下,叫my.cnf (如果找不到的話也有可能在這些目錄下:/etc/my.cnf,/etc/mysql/my.cnf,/usr/local/mysql/etc/my.cnf,~/.my.cnf)

[mysqld]

basedir=/usr/local/mysql

datadir=/data/mysqldata

socket=/tmp/mysql.sock

user=mysql

server-id=1

port=3306

 

server-id=1 #伺服器id (主從必須不一樣)

log-bin=mysql-bin #開啟日誌(主機需要開啟),這個mysql-bin也可以自定義,這裡也可以加上路徑

#作為主機的配置

binlog-do-db=employees #要給從機同步的庫

#binlog-do-db=

binlog-ignore-db=mysql #不給從機同步的庫(多個寫多行)

binlog-ignore-db=information_schema

binlog-ignore-db=performance_schema

binlog-ignore-db=sys

expire_logs_days=7 #自動清理 7 天前的log檔案,可根據需要修改

[root@001 employees_db]# service mysqld restart #重啟資料庫

測試log_bin是否成功開啟

mysql> show variables like '%log_bin%';

2、master的資料庫中建立備份賬號:backup為使用者名稱,%表示任何遠端地址,如下表示密碼為1234的任何遠端地址的backup都可以連線master主機

mysql> grant replication slave on *.* to 'backup'@'%' identified by '123456';

mysql> use mysql

mysql> select user,authentication_string,host from user;

3、拷貝資料

重啟MySQL服務並設定讀取鎖定,讀取鎖定的意思是隻能讀取,不能更新,以便獲得一個一致性的快照

mysql> show master status\G #

檢視主伺服器上當前的二進位制日誌名和偏移量值這裡的file 和position 要和從上的一致

匯出master(192.168.1.222)種的資料,然後匯入slave 中

master:

[root@001 employees_db]# mysqldump -uroot -p123456 -hlocalhost employees > /opt/employees.bak

[root@001 employees_db]# yum install openssh-clients -y #(注:slave也需要安裝)

slave:

[root@001 employees_db]# yum install openssh-clients -y

[root@001 ~]# scp /opt/employees.bak root@192.168.1.233:/opt/

root@192.168.1.233's password: #輸入密碼

employees.bak 100%

4、配置slave(192.168.1.233)

[root@002 ~]# vim /etc/my.cnf

[mysqld]

basedir=/usr/local/mysql #mysql路徑

datadir=/data/mysqldata #mysql資料目錄

socket=/tmp/mysql.sock

user=mysql

server_id=2 #MySQLid 後面2個從伺服器需設定不同

port=3306

 #加上以下引數可以避免更新不及時,SLAVE 重啟後導致的主從複製出錯。

read_only = 1

master_info_repository=TABLE

relay_log_info_repository=TABLE

#relay_log_recovery=1 #從機禁止寫

#super_read_only=1 #從機禁止寫

 

然後匯入到mysql資料庫中,slave上的employees資料庫不存在則先建立,然後再匯入

mysql> create database employees;

[root@002 ~]# mysql -uroot -p123456 -hlocalhost employees < /opt/employees.bak

[root@002 ~]# service mysqld restart

登入slave資料庫,並做如下設定

[root@002 ~]# mysql -uroot -p123456

mysql> stop slave;

mysql> change master to

-> master_host='192.168.1.222', #master的ip

-> master_user='backup', #備份使用者名稱

-> master_password='123456', #密碼

-> master_log_file='mysql-bin.000002', #上面截圖,且要與master的引數一致

-> master_log_pos=154; #上面截圖,且要與master的引數一致

mysql> start slave;

檢視slave從機的狀態

mysql> show slave status \G

圖中2個yes 代表設定成功

5、關閉掉主資料庫的讀取鎖定,並測試

 mysql> unlock tables;

在marster中建立一個新表再檢視slave中是否有資料

master:

mysql> use employees;

mysql> create table test001(id int auto_increment primary key,name varchar(20) not null);

mysql> insert into test001 values(null,'will');

mysql> insert into test001 values(null,'jim');

mysql> insert into test001 values(null,'tom');

slave:

mysql> use employees;

mysql> show tables;

mysql> select * from test001;

測試2:重啟關閉從資料庫,主刪除test001表,然後主從資料庫都重啟看是否正常

mysql> drop table test001;

相關文章