MySQL 5.7.18的安裝與主從複製html
IPmysql |
計算機名linux |
角色sql |
192.168.1.222數據庫 |
001vim |
master服務器 |
192.168.1.233ssh |
002socket |
slaveide |
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,也可執行創建
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;
以上實驗證實主從同步成功!!!