1. 程式人生 > >mysql+centos7+主從復制

mysql+centos7+主從復制

恢復 原理 ria 原因 命令 有效 安裝 機制 global

MariaDB數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,采用GPL授權許可。
開發這個分支的原因之一是:甲骨文公司收購了MySQL後,有將MySQL閉源的潛在風險,因此社區采用分支的方式來避開這個風險。
MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能輕松成為MySQL的代替品。

方法1:yum安裝mariadb

技術分享圖片

yum install mariadb-server mariadb 

相關命令

mariadb數據庫的相關命令是:

systemctl start mariadb  #啟動MariaDB

systemctl stop mariadb  #停止MariaDB

systemctl restart mariadb  #重啟MariaDB

systemctl enable mariadb  #設置開機啟動

啟動後正常使用mysql

systemctl start mariadb

#進入mysql
mysql -uroot -p

方法2:官網下載mysql-server包(rpm)

# wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
# rpm -ivh mysql-community-release-el7-5.noarch.rpm
# yum install mysql-community-server

配置mysql

1.中文編碼設置

編輯mysql配置文件/etc/my.cnf
[mysqld]
character-set-server=utf8
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
collation-server=utf8_general_ci

security risks
symbolic-links=0
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

2.授權配置

遠程連接設置哦設置所有庫,所有表的所有權限,賦值權限給所有ip地址的root用戶
mysql > grant all privileges on *.* to root@‘%‘ identified by ‘password‘;
#創建用戶
mysql > create user ‘username‘@‘%‘ identified by ‘password‘;
#刷新權限
flush privileges;

MYSQL主從復制

MySQL數據庫的主從復制方案,是其自帶的功能,並且主從復制並不是復制磁盤上的數據庫文件,而是通過binlog日誌復制到需要同步的從服務器上。

MySQL數據庫支持單向、雙向、鏈式級聯,等不同業務場景的復制。在復制的過程中,一臺服務器充當主服務器(Master),接收來自用戶的內容更新,而一個或多個其他的服務器充當從服務器(slave),接收來自Master上binlog文件的日誌內容,解析出SQL,重新更新到Slave,使得主從服務器數據達到一致。

主從復制的邏輯有以下幾種

一主一從,單向主從同步模式,只能在Master端寫入數據

一主多從

技術分享圖片

雙主主復制邏輯架構,此架構可以在Master1或Master2進行數據寫入,或者兩端同事寫入(特殊設置)

技術分享圖片

在生產環境中,MySQL主從復制都是異步的復制方式,即不是嚴格的實時復制,但是給用戶的體驗都是實時的。
MySQL主從復制集群功能使得MySQL數據庫支持大規模高並發讀寫成為可能,且有效的保護了服務器宕機的數據備份。

應用場景

利用復制功能當Master服務器出現問題時,我們可以人工的切換到從服務器繼續提供服務,此時服務器的數據和宕機時的數據幾乎完全一致。
復制功能也可用作數據備份,但是如果人為的執行drop,delete等語句刪除,那麽從庫的備份功能也就失效了.

主從機制實現原理

技術分享圖片

(1) master將改變記錄到二進制日誌(binary log)中(這些記錄叫做二進制日誌事件,binary log events); 
(2) slave將master的binary log events拷貝到它的中繼日誌(relay log); 
(3) slave重做中繼日誌中的事件,將改變反映它自己的數據。

master主庫配置

#查看數據庫狀態
systemctl status mariadb
#停mariadb
systemctl stop mariadb

#修改配置文件
vim /etc/my.cnf
#修改內容
#解釋:server-id服務的唯一標識(主從之間都必須不同);log-bin啟動二進制日誌名稱為mysql-bin

  [mysqld]
  server-id=1
  log-bin=mysql-bin

#重啟mariadb
systemctl start mariadb

master主庫添加從庫賬號

1.新建用於主從同步的用戶chaoge,允許登錄的從庫是‘192.168.178.130‘
create user ‘chaoge‘@‘192.168.178.130‘ identified by ‘redhat‘;

2.#題外話:如果提示密碼太簡單不復合策略加在前面加這句
mysql> set global validate_password_policy=0;

3.給從庫賬號授權,說明給chaoge從庫復制的權限,在192.168.178.130機器上復制
grant replication slave on *.* to ‘chaoge‘@‘192.168.178.130‘;
#檢查主庫創建的復制賬號
select user,host from mysql.user;
#檢查授權賬號的權限
show grants for chaoge@‘192.168.178.130‘;

實現對主數據庫鎖表只讀,防止數據寫入,數據復制失敗
flush table with read lock;

4.檢查主庫的狀態

MariaDB [(none)]> show master status
-> ;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 575 | | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

File是二進制日誌文件名,Position 是日誌開始的位置。後面從庫會用到 後面從庫會用到 後面從庫會用到!!!!!!

5.鎖表後,一定要單獨再打開一個SSH窗口,導出數據庫的所有數據,

[root@oldboy_python ~ 19:32:45]#mysqldump -uroot -p --all-databases > /data/all.sql

6.確保數據導出後,沒有數據插入,完畢再查看主庫狀態

show master status;

7.導出數據完畢後,解鎖主庫,恢復可寫;

unlock tables;

8.將備份導出的數據scp至Slave數據庫

scp /data/all.sql [email protected]:/data/

slave從庫配置

1.設置server-id值並關閉binlog功能參數
數據庫的server-id在主從復制體系內是唯一的,Slave的server-id要與主庫和其他從庫不同,並且註釋掉Slave的binlog參數。
2.因此修改Slave的/etc/my.cnf,寫入
[mysqld]
server-id=3
3.重啟數據庫
systemctl restart mariadb
4.檢查Slava從數據庫的各項參數
show variables like ‘log_bin‘;
show variables like ‘server_id‘;
5.恢復主庫Master的數據導入到Slave庫
導入數據(註意sql文件的路徑)
mysql>source /data/all.sql;
方法二:
#mysql -uroot -p < abc.sql
6.配置復制的參數,Slave從庫連接Master主庫的配置
mysql > change master to master_host=‘192.168.178.129‘,
master_user=‘chaoge‘,
master_password=‘redhat‘,
master_log_file=‘mysql-bin.000001‘,
master_log_pos=575;
7.啟動從庫的同步開關,測試主從復制的情況
start slave;
8.查看復制狀態
show slave status\G;

檢查主從復制是否成功的關鍵在於

mysql+centos7+主從復制