MySQL 5.7.18的安裝及主從復制(主從同步)


MySQL 5.7.18的安裝與主從復制

IP

計算機名

角色

192.168.1.222

001

master

192.168.1.233

002

slave

CentOS 6.9安裝mysql5.7.18 #這里只展示一台的安裝過程,另一台一樣操作

下載地址:https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz

1、下載,解壓,並創建軟鏈接

[root@001 ~]# wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz

[root@001 ~]# tar xf mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz -C /usr/local/

[root@001 ~]# cd /usr/local/

[root@001 local]# ln -sv mysql-5.7.18-linux-glibc2.5-x86_64/ mysql

2、新建mysql用戶組和mysql用戶

[root@001 local]# groupadd mysql

[root@001 local]# useradd -g mysql -r -s /sbin/nologin -M -d /data/mysqldata mysql

3、新建數據目錄並賦予相關屬組及權限

[root@001 local]# chown -R mysql:mysql /usr/local/mysql

[root@001 local]# mkdir -p /data/mysqldata

[root@001 local]# chmod -R 770 /data/mysqldata

[root@001 local]# chown -R mysql:mysql /data/mysqldata

4、初始化mysqld

[root@001 local]# cd /usr/local/mysql

[root@001 mysql]# ./bin/mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysqldata --initialize

初始化完成后需記錄下初始化密碼

5、編輯配置文件及將mysql的服務腳本放到系統服務中,並配置環境變量讓系統可以直接使用mysql的相關命令

[root@001 mysql]# cp support-files/mysql.server /etc/init.d/mysqld

[root@001 mysql]# ldconfig

[root@001 mysql]# echo "PATH=$PATH:/usr/local/mysql/bin" > /etc/profile.d/mysql.sh

[root@001 mysql]# source /etc/profile.d/mysql.sh

[root@001 mysql]# chkconfig mysqld on

[root@001 mysql]# vim /etc/my.cnf

[mysqld]

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

datadir=/data/mysqldata #mysql數據目錄

socket=/tmp/mysql.sock

user=mysql

server_id=1 #MySQLid 后面2個從服務器需設置不同

port=3306

[root@001 mysql]# service mysqld start #啟動mysql

Starting MySQL.Logging to '/data/mysqldata/001.err'.

. SUCCESS! #啟動成功

6、修改密碼

[root@001 mysql]# mysql -uroot -pdSrp%=Gdw4y: #這里的密碼上剛才記錄下來的

mysql> set password='123456';

mysql> FLUSH PRIVILEGES;

7、設置mysql遠程可訪問(前提是防火牆必須關閉,chkconfig iptables off:設置自動啟動為關閉,service iptables sto:關閉防火牆)

[root@001 mysql]# service iptables stop

[root@001 mysql]# chkconfig iptables off

先登錄到mysql

mysql> use mysql;

mysql> update user set host = '%' where user = 'root'; #按實際情況設置

mysql> flush privileges;

----以上是上台測試機安裝MySQL5.7.18的全部步驟----

----下面開始配置MySQL5.7.18 的主從復制----

MySQL主從復制

IP

計算機名

角色

192.168.1.222

001

master

192.168.1.233

002

slave

#這里先導入測試數據庫用於同步詳見:http://www.cnblogs.com/imweihao/p/7286926.html,也可執行建立

1master上開啟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%';

2master的數據庫中建立備份賬號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', #masterip

-> 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

圖中2yes 代表設置成功

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;

 

 

以上實驗證明主從同步成功!!!

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM